查询不返回数据库

时间:2015-12-14 13:39:46

标签: java postgresql

我正在尝试使用值FK_adId从我的数据库中获取汽车。我尝试使用FK_adId值52调用方法,并且检查了数据库中存在FK_adId值为52的汽车。为什么不归还给我?

public Car getCar(int adId) {
    Car car = null;
    try {
        Class.forName("org.postgresql.Driver");
        if (con != null) {
            ps = con.prepareStatement("SELECT * FROM \"car\" WHERE \"FK_adId\" = ?;");
            ps.setInt(1, adId);
            rs = ps.executeQuery();
            rs.next();
            if (rs.next()) {
                car = new Car(rs.getString("brand"), rs.getString("vin"), rs.getString("condition"), rs.getInt("distanceTraveled"), rs.getInt("age"), rs.getInt("price"), rs.getInt("FK_adId"));
            }
        }
    } catch (Exception ex) {
        System.out.println(ex);
    }
    return car;
}

1 个答案:

答案 0 :(得分:6)

        rs.next();
   if (rs.next()) {

拨打.next()一次,而不是两次。您前进到结果的第一行,然后前进到第二行。由于查询没有返回两行,因此不会获得第二行。你跳过了你想要的那一行。