Java中有两个Date类,java.util.Date和java.sql.Date,java.util.Date是java.sql.Date的父类,两者存在一些异同,总结如下:
(1)都是时间类,java.util.Date是java.sql.Date的父类;
(2)java.sql.Date是针对数据库使用的,只有日期部分,没有时间部分,格式为yyyy-mm-dd
(3)java.util.Date可以用于数据库,也可用于其他地方,包含日期和时间,格式为yyyy-mm-dd hh:mm:ss;
(4)sql.date没有无参构造方法
例如:System.out.println(new Date(System.currentTimeMillis()));//返回2021-05-25
(5)通常使用java.util.Date来生成入库的时间
在今天的项目中有个需求,domain实体类File中有个文件发布时间属性,后端接收前端传入的包括文件发布时间在内的一些字符串自动转为实体对象再存储到数据库,然后再以yyyy-mm-dd的形式展示在前端。
如果用实体类File中的发布时间publishDate用java.util.Date定义的话,前端传入的string字符串数据可以正常转为实体对象中的属性,但是如果返回给前端的FileDto对象中的publishDate还是用java.util.Date定义的话就会返回yyyy-mm-dd 00:00:00这种形式的数据,但是,我们只需要展示到日期即可,所以FileDto对象中的publishDate就可以用java.sql.Date定义,得到的数据就没有后面的时分秒了,就能够达到项目需求了。
两种时间类型的转换都是通过getTime这个方法获得一个长整型字符串,再构造一个新的对象接收,所以不存在类型转换的问题。
补充:
(1)java.sql包下给出三个与数据库相关的日期时间类型:
Date:表示日期,只有年月日,没有时分秒。会丢失时间;
Time:表示时间,只有时分秒,没有年月日。会丢失日期;
Timestamp:表示时间戳,有年月日时分秒,以及毫秒。
(2)两者之间的转换关系
java.sql.Date sqlDate=new java.sql.Date(new java.util.Date.getTime());