- 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/
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!