一、时间类的类型
Java中的时间类为java.util.Date
MySQL对应的时间类为java.sql.Date
- 其中java.util.Date为java.sql.Date的父类,
- 所以,在Java中创建的java.util.Date不能直接通过JDBC操作,插入到数据库中.
- 通过JDBC查询数据库的时间java.sql.Date可以赋值给Java中的java.util.Date
解决方案:
- 通过时间转换成long型长整数,转换时间类型
util.Date转sql.Date
java.sql.Date date1 = new java.sql.Date(new java.util.Date().getTime());
sql.Date转util.Date
//date1为上面代码片中的Date
java.util.Date date2 = new java.util.Date(date1.getTime());
二、JDBC存储时间
若数据库对应的时间类型为datetime
yyyy-MM-dd HH:mm:ss
//PreparedStatement的setDate()方法会将sql包下Date的时分秒割掉,时分秒存入数据库后为00:00:00
ps.setDate(3, new java.sql.Date(new Date().getTime()));
//PreparedStatement的setTimestamp方法才可以正确存储时间,包括年月日时分秒
ps.setTimestamp(3,new Timestamp(blogs.getTime().getTime()));

本文介绍了Java中的java.util.Date和MySQL中的java.sql.Date之间的关系以及如何在JDBC操作中进行时间类型的转换。由于java.util.Date是java.sql.Date的父类,故在JDBC操作中不能直接使用java.util.Date,需要将其转换为long类型或者通过特定方法转换为java.sql.Date。同时,文章提到了当数据库时间类型为datetime时,格式为'yyyy-MM-dd HH:mm:ss'。





