- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在程序中处理不同格式的日期时遇到困难。
现在,我的查询已执行,但我从数据库中以 YYYY-MM-DD 格式获取日期。我希望它们采用 DD-MM-YYYY HH:mm 格式。
在 SQL 文件中,日期的定义如下(在 INSERT INTO 指令中):
to_date('2015/05/15 12:00', 'yyyy/mm/dd hh24:mi')
在我的java代码中,我尝试让用户选择一个日期(Date对象是java.util.date):
DateFormat formater = new SimpleDateFormat("DD-MM-YYYY HH:mm", Locale.FRENCH);
String dateString;
dateString = sc.nextLine();
Date upperDate = formater.parse(dateString);
// a "lowerDate is also that way.
List<Train> listTrains = new ArrayList<>();
listTrains = manager.WhenTrain(departure_city, arrival_city, upperDate, lowerDate);
for(int i = 0; i<liste.size(); i++)
{
System.out.println(listTrains.get(i));
}
在一个方法中,我尝试获取与各种条件相对应的值,其中包括日期,所以我有:
在构造函数和字段中:
private PreparedStatement AllTrains;
private PreparedStatement LookForDepartureStation;
AllTrains = connection.prepareStatement("SELECT * FROM Trains"
+ "WHERE departure = ? AND arrival = ? AND departurehour BETWEEN ? AND ?"); // Trains is a view, joining several table
LookForDepartureStation = connection.prepareStatement("SELECT * from Journey where departure = ?");
另一种方法:
public List<Train> WhenTrain(String departureStation, String arrivalStation, java.util.Date dateBefore, java.util.Date dateAfter) {
ArrayList<Train> TrainList= new ArrayList<>();
try {
java.sql.Date begin = new java.sql.Date(dateBefore.getTime());
java.sql.Date end = new java.sql.Date(dateAfter.getTime());
LookForDepartureStation.setString(1, departureStation);
ResultSet test1 = LookForDepartureStation.executeQuery();
if(test1.next()){
LookForDepartureStation.close();
LookForArrivalStation.setString(1, arrivalStation);
ResultSet test2 = LookForArrivalStation.executeQuery();
if(test2.next()) {
LookForArrivalStation.close();
AllTrains.setString(1, departureStation);
AllTrains.setString(2, arrivalStation);
AllTrains.setDate(3, begin);
AllTrains.setDate(4, end);
ResultSet rs = AllTrains.executeQuery();
while(rs.next()){
TrainList.add(new Train(rs.getInt(1),
rs.getString(2), rs.getString(3), rs.getDate(4), rs.getDate(5)));
// Train is an object to take all those.
// AllTrains contains TrainID (an oracle integer), departure (varchar2), arrival (varchar2), departurehour (sql oracle DATE), arrivalhour (sql oracle DATE)
}
// AllTrains.close();
return ListeTrains;
}
else {
System.out.println("wrong input on arrival station");
// AllTrains.close();
TrainApp.Alltrains(this);
return TrainList;
}
}
else {
System.out.println("wrong input on departure station");
return TrainList;
}
} catch (SQLException error) {
error.printStackTrace();
return TrainList;
}
catch(NullPointerException e) {
System.out.println("Station not found");
e.printStackTrace();
TrainApp.Alltrains(this); // calling back static method to try again the input.
return TrainList;
}
}
当我尝试在方法中传递 Upperdate 时,调试器显示该变量包含:“1 janv.0003 00:00:00”(实际上我尝试使用 03-11-1993)。此外,我认为它不会将我想要的日期放入 Train 对象中,我想我也搞砸了。
程序结束时没有显示列表中的内容(方法调用后的说明,如您在此处的第二个代码引用中看到的那样)。
最佳答案
如果不知道 upperDate 和 lowerDate 的值,就很难理解为什么它们没有被正确解析。
查询的问题在于 java.sql.Date
将输入中的 java.util.Date
值四舍五入为日期,即它重置了时间部分。如果您想查询并检索包含时间部分的正确结果,则必须使用 java.sql.TimeStamp。尝试将 begin
和 end
类型更改为 java.sql.TimeStamp
和 rs.getDate(4)、rs.getDate(5)
到 rs.getTimestamp(4)、rs.getTimestamp(5)
这种误解通常是因为 Oracle 中的 Date 类型还包含时间部分,但在其他 RDBMS 中,日期类型“仅”代表日期
关于java - 处理日期 java.util、日期 java.sql 和 SimpleDateFormat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30510742/
我们在 java.util.Date 对象的 JAXB 序列化/反序列化过程中使用 SimpleDateFormat,我正在编写以下实用程序来实现这一点 public DateFormat getDa
我正在尝试借助 SimpleDateFormat 将时区设置为不同国家/地区的时区。 SimpleDateFormat.format() 返回给定时区的正确当前时间,但 SimpleDateForma
我正在尝试将 DatePicker 日期格式化为 SimpleDateFormat(“yyyy-MM-dd HH:mm:ss Z”)。有人告诉我,我需要使用 SimpleDateFormatter 将
我遇到this article并感到困惑 在我们的项目中,有几个地方我们使用 ThreadLocal 来构造 ThreadLocal 变量 在其他一些地方,我们在私有(private)本地方法中构造了
在创建 Date 对象期间,我遇到了一个奇怪的问题。我有以下代码将日期的时区设置为 UTC。在解析语句之前,我看到 sdfDate 的时区为 UTC,但在解析语句之后,我看到 PunchDate 具有
我的日期格式如下:2010-03-01T00:00:00-08:00 我已经抛出了以下 SimpleDateFormats 来解析它: private static final SimpleDateF
我有一个从给定日期中提取确切时间的逻辑(例如: 12:00 PM )。 在逻辑的最后,我使用了 SimpleDateFormat解析日期。 当我在 Android 设备上运行代码时,一切正常。 此外,
根据下图,当我使用 item.takendate至SimpleDateFormat 我得到了 《2016年1月》而不是 《2017年1月》 这里发生了什么?请指教。 编辑 但是,当我使用 cdate
我正在尝试使用 java.text.SimpleDateFormat 将日期字符串解析为 java.util.Date;但是,生成的格式化日期是错误的。 这是一个显示问题的测试用例: @Test pu
我正在尝试将“5 月 15 日星期一下午 1 点”格式的字符串解析为日期时间,以便我可以将其输入到数据库中。但是,当我对此进行测试时,解析并没有在正确的日子返回。有谁知道发生了什么? import j
背景: 在我的数据库表中,我有两个时间戳 timeStamp1 = 2011-08-23 14:57:26.662 timeStamp2 = 2011-08-23 14:57:26.9 当我执行“OR
我需要解析以下来自网络服务的日期。 2014-09-16T18:05:00.000-05:00 所以我尝试创建 SimpleDateFormat 对象 SimpleDateFormat simpleD
我很困惑为什么 SimpleDateFormat 没有正确解析以下输入数据。 我试图在 String 上测试各种可能允许的日期格式,看看它是否可以使用其中一种格式正确解析。 注意:我使用的其他不正确的
我想将字符串存储到具有当前时间和日期的 Android 应用程序的数据库(SQLite)中。为此,我正在使用 SimpleDateFormat。不幸的是,它没有显示正确的时间。我尝试了两种选择。 第一
也许这个问题很傻,但我没有找到令我满意的答案。 我有一个 SimpleDataFormat,例如: sdf = new SimpleDateFormat("dd/MM/yyyy"); 如果我尝试解析这
这里我尝试比较 3 个日期,为此,我已将一个日期和两个字符串传递给函数。我使用简单的日期格式来制作 3 个相同格式的日期,以便我可以比较它们。但是对于两个字符串值,我在解析它时得到了错误的日期。有人可
我正在尝试将日期从 2009 年 5 月 15 日 19:24:11 PM MDT 转换为 20090515192411。但是当我尝试下面的代码时,读取格式本身将输入视为 5 月 16 日而不是 5
这个问题已经有答案了: How to get date from date time in java (6 个回答) Why can't this SimpleDateFormat parse thi
这个问题已经有答案了: Changing Java Timestamp format causes a change of the timestamp (2 个回答) Java / convert I
以下代码: SimpleDateFormat sdf = new SimpleDateFormat("MM/dd"); System.out.println(sdf.format(new Date(1
我是一名优秀的程序员,十分优秀!