一、时间类的类型
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()));