对于PreparedStatement类型,未定义getInt,getString和getDate方法

问题描述 投票:0回答:2

您好我不断收到此错误:对于PreparedStatement类型,未定义方法getInt(String / int / Date)(在IDE中显示以下每行的错误:以下行:

            int placeNo = myStmt.getInt("NR_MIEJSCA");
            Date start = myStmt.getDate("START");
            Date end = myStmt.getDate("KONIEC");
            String userName = myStmt.getString("IMIE_NAZWISKO");
            int phone = myStmt.getInt("TELEFON");

这是我发送特定停车位ID查询的方法:

    public List<Book> getSpecBook(int id) throws Exception {
    List<Book> books = new ArrayList<>();

    //int idInt = Integer.parseInt(id);

    Connection myConn = null;
    PreparedStatement myStmt = null;
    ResultSet myRs = null;

    try {
        myConn = dataSource.getConnection();

        // create sql statement
        String sql = "SELECT * FROM `rezerwacje_miejsc` WHERE `NR_MIEJSCA`=?";

        myStmt = myConn.prepareStatement(sql);
        myStmt.setInt(1, id);

        myRs = myStmt.executeQuery();

        while (myRs.next()) {
            // retrive data from result set row
            int placeNo = myStmt.getInt("NR_MIEJSCA");
            Date start = myStmt.getDate("START");
            Date end = myStmt.getDate("KONIEC");
            String userName = myStmt.getString("IMIE_NAZWISKO");
            int phone = myStmt.getInt("TELEFON");

            // create new temporary Book object
            Book tempBook = new Book(placeNo, start, end, userName, phone);

            // add it to our list of Books
            books.add(tempBook);
        }

        return books;

    } finally {
        // clean up JDBC objects
        close(myConn, myStmt, myRs);
    }
}

这是我的API类:

package com.pbs.web.controller;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.pbs.web.jdbc.ParkingBookSystem.Book;
import com.pbs.web.jdbc.ParkingBookSystem.BookDbUtil;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import java.util.List;

@Path("books")
@Produces(MediaType.APPLICATION_JSON)
public class BookingRestController {
    private BookDbUtil bookDbUtil = new BookDbUtil();

    @GET
    @Path("/")
    public Response getAllBooks() throws Exception {
        List<Book> books = bookDbUtil.getBooks();
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(books);
        return Response.ok().entity(json).build();
    }

    @GET
    @Path("/{id}")
    public Response getSpecBook(@PathParam("id") int id) throws Exception {
        List<Book> books = bookDbUtil.getSpecBook(id);
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(books);
        return Response.ok().entity(json).build();
    }
}

我认为我准备的陈述有一些内容,但我无法找到问题。

java rest api jdbc prepared-statement
2个回答
1
投票

您正在PreparedStatement上调用getInt()和getDate()。这些功能在那里不存在:https://docs.oracle.com/javase/7/docs/api/java/sql/PreparedStatement.html

但是,它们确实存在于ResultSet;):https://docs.oracle.com/javase/7/docs/api/java/sql/ResultSet.html

所以不是这样的:

while (myRs.next()) {
    // retrive data from result set row
    int placeNo = myStmt.getInt("NR_MIEJSCA");
    Date start = myStmt.getDate("START");
    Date end = myStmt.getDate("KONIEC");
    String userName = myStmt.getString("IMIE_NAZWISKO");
    int phone = myStmt.getInt("TELEFON");

    // create new temporary Book object
    Book tempBook = new Book(placeNo, start, end, userName, phone);

    // add it to our list of Books
    books.add(tempBook);
}

试试这个:

while (myRs.next()) {
    // retrive data from result set row
    int placeNo = myRs.getInt("NR_MIEJSCA");
    Date start = myRs.getDate("START");
    Date end = myRs.getDate("KONIEC");
    String userName = myRs.getString("IMIE_NAZWISKO");
    int phone = myRs.getInt("TELEFON");

    // create new temporary Book object
    Book tempBook = new Book(placeNo, start, end, userName, phone);

    // add it to our list of Books
    books.add(tempBook);
}

0
投票

getIntgetDategetStringResultSet方法,而不是PreparedStatement方法。尝试:

int placeNo = myRs.getInt("NR_MIEJSCA");
Date start = myRs.getDate("START");
Date end = myRs.getDate("KONIEC");
String userName = myRs.getString("IMIE_NAZWISKO");
int phone = myRs.getInt("TELEFON");
© www.soinside.com 2019 - 2024. All rights reserved.