循环访问数据库中的条目问题

时间:2017-11-23 22:06:21

标签: java sql ms-access resultset

我试图通过Java访问我的Access数据库,以检查日期范围是否介于另一个日期范围之间,以避免重复预订。我遇到一个SQL错误,说“ResultSet已关闭”。我相信这是因为我使用两个resultSet来检查两个不同的日期和一个while循环。这是代码:

String date1Query = "SELECT checkIn FROM Reservation WHERE roomLocation LIKE '" + room + "'";
String date2Query = "SELECT checkOut FROM Reservation WHERE roomLocation LIKE '" + room + "'";

ResultSet date1RS = statement.executeQuery(date1Query);
ResultSet date2RS = statement.executeQuery(date2Query);
    while (date1RS.next()) {
        date1 = date1RS.getDate("checkIn");
        date2 = date2RS.getDate("checkOut");
        dateCheckBool = dateCheck.dateCheck(date1, date2, checkIn, checkOut);    

        if (dateCheckBool == true)
            break;
    }

我还能如何格式化以实现相同的功能(能够根据数据库中已有的日期检查用户的输入日期)但不会出错?如果这还不够明确,我会尝试根据要求进一步澄清。谢谢!

编辑:这里要求的是dateCheck代码:

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class dateCheck {
    public boolean dateCheck(Date date1, Date date2, String date3, String 
date4){
    DateFormat dateFormat = new SimpleDateFormat("MM/dd/yyyy");
    Date dateCheck1;
    Date dateCheck2;
    boolean dateRange1 = false;
    boolean dateRange2 = false;
    try {
        dateCheck1 = dateFormat.parse(date3);
        dateCheck2 = dateFormat.parse(date4);

        if(dateCheck1.before(date1) || dateCheck1.after(date2))
            dateRange1 = false;
        else
            dateRange1 = true;
        if(dateCheck2.after(date2))
            dateRange2 = false;
        else
            dateRange2 = true;
    } catch (ParseException e) {
        e.printStackTrace();
    }
    if(dateRange1 == false && dateRange2 == false)
        return false;
    else
        return true;
    }
}

1 个答案:

答案 0 :(得分:0)

为什么单独使用SQL可以为您提供结果呢?

如果您想知道预订是否已经到位,请询问数据库。

 SELECT id as result From reservations
 Where (
        ([RoomLocation] like ?)
        And (
            (? between [checkin] and [checkout])
            OR (? between [checkin] and [checkout])
        ) 
);
你的java中的

statement.setString(1,room);
statement.setDate(2,date1);
statement.setDate(3,date2);

.. ..执行

如果有任何预订,您将收到预订ID。如果不为null。您还可以将SQL放在另一个select命令中,并返回true或false值。 如果您遇到与不兼容的日期格式有关的问题,则可能必须格式化日期并将其作为字符串传递。

Ps:从手机回答,仔细检查SQL是否存在错别字。