java中获取数据库时间丢失分秒问题

在java中常用的时间格式类型为:java.util.Date  和java.sql.Date。

本文主要讲解三点:

1.java.util.Date与java.sql.Date的区别。

2.时间转换的方式。

3.时间转换过程中需要注意的地方。


第一点:1.java.util.Date,java.sql.Datejava.sql.Time的区别。

java.util.Date 是 java.sql.Date 的父类

java.util.Date是不能直接插入数据库中的,虽然它包含了日期和时分秒。

java.sql.Date可以直接插入数据库,但是它只有日期而没有时间;

java.sql.Time可以直接插入数据库,但是它只有时间,没有日期;

java.util.Date 就是在除了SQL语句的情况下面使用,我们通常格式化或者得到当前时间都是用他。java.sql.Date 是针对SQL语句使用的,一般在读写数据库的时候用他,因为PreparedStament的setDate()的第2参数和ResultSet的getDate()方法的第2个参数都是java.sql.Date


第二点:2.时间转换方式

方式一:util.Date转为sql.Date  [将时间数据插入导数据库中]

java.sql.Date date=new java.sql.Date();

java.util.Date d=new java.util.Date (date.getTime());



方式二:【java.util.Date转化为java.sql.Timestamp】[获取时间的时分秒丢失问题]

前景描述:

如若要取得时分秒,可以用Date的子类TimestampJava在向数据库中插入时间的时候,常常遇到时、分、秒丢失的情况,这种情况的发生一般是由于时间日期对象使用错误造成的。

如果我们要插入日期和时间,那么就要想办法来使用java.sql.Timestamp来向数据库插入。java.sql.Timestamp可包含了日期和到毫秒的时间值,在程序中,我们常常是使用的java.util.Date,所以就要有解决的方法来实现。

有如下方法将java.util.Date转化为java.sql.Timestamp

public java.sql.Timestamp getTimestamp(Date date) {

return new java.sql.Timestamp(date.getTime());

}

这样,我们可以将我们使用的java.util.Date转化,然后插入数据库,便可以解决时、分、秒丢失的问题。


第三点:时间转换过程中需要注意的地方。

注意点:[java中Date无法获取数据库时分秒的问题]

举例

数据库中关于时间的分秒值都有,但是通过rs.getDate(“字段名”)取出的时间只有年月日,丢失了具体的时间。

知识点:java.sql.Date是只支持日期的,不支持时分秒。

而java.util.Date是有时间部分的。

在sql操作的时候,resultSet中getDate()默认的类型是java.sql.Date,所以获取的Date类型是没有时间部分的,setDate(rs.getTimestamp('time')),使用rs.getTimestamp()能够很好的解决这个问题,记住setDate()的Date一定要是java.util.Date类型

解决方法:rs.getTimestamp('time')

参考链接:

java中Date无法获取数据库时分秒的问题

java.util.Date和java.sql.Date的区别和相互转化

解决数据库中插入时间丢失时分秒

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,983评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 9,291评论 0 11
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,064评论 19 139
  • 这些文字,请你心平气和的看下去。 你现在的情况,非常令家人担心。你遇到喜欢的人,在谈恋爱是件喜事,我和爸妈都替你高...
    迈腾330阅读 1,873评论 0 0
  • 有一个人 想脱离一个人 也许是一个人不喜欢一个人了吧 偏偏这时候一个人发现自己得了病 它不知道怎么来 于是他们又联...
    amadaan阅读 1,706评论 0 0

友情链接更多精彩内容