解决hibernate中使用new Date() 造成oracle date类型时分秒精准度丢失

在hibernate中使用new Date() 如果配置不好造成oracle date类型时分秒精准度丢失

比如你很有信心的把new Date()插入数据库,后来select后发现所有数据日期都显示为 2010-06-08 12:00:00这样的格式.

昨天我也遇到了这个问题,在试了很多网上的方法后在CSDN的一个跟帖中找到了最佳方案,而且也成功了。

————————

大概做如下修改

1  首先是你的pojo的xml配置文件:

    把date类型换成timestamp

    <property name="creationTime" type="timestamp">

2 吧你使用new date()的地方改成

   java.util.Date currentTime = new java.sql.Timestamp(System.currentTimeMillis());

   www.gbsou.com.IqcAssyRec rec = new  www.gbsou.com.IqcAssyRec();
   rec.setCreationTime(currentTime);

   就可以了。

——————-

但是如果你的POJO采用的是注解Annotation风格

  1. @Column(name = "Last_Update_Time"
  2. @Temporal(value = TemporalType.TIMESTAMP) 
  3. private Date lastUpdateTime; 

可以直接使用 new Date();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值