JDBC对数据库时间的操作

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

你可能感兴趣的:(MySQL,JavaEE)