我试图通过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;
}
}
答案 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是否存在错别字。