`

hiberante date存入数据库时没有time

 
阅读更多

Hibernate在保存和更新Date类型的数据到数据库的时候,如果设置不当,会舍弃时分秒,和数据库中Date类型的精确度不符(如Oracle的Date是带时分秒的).

引起的原因主要是mapping文件中的字段类型被设成了type="date",而mapping文件一般都是通过hibernate提供的工具生成的,hibernate提供的工具默认把数据库端date型的字段设成type="date".从而Hibernate在用JDBC做数据库更新的时候会用 statement的setDate(index, sqlDate),插入数据库的日期只有年月日.

下面的JDBC代码演示了这个问题:

String sql = "UPDATE Timetest T SET T.datev=? WHERE T.id=?";
stmt = conn.prepareStatement(sql);

// java.sql.Date sqlDate = new java.sql.Date(26,7,2010);
// sqlDate.setTime(System.currentTimeMillis());
// stmt.setDate(1, sqlDate); //如果是用setdate的方式,时分秒会被舍弃


//用setTimestamp的方式,时分秒会被保存
stmt.setTimestamp(1, new Timestamp(System.currentTimeMillis()));

stmt.setLong(2, 1L);
stmt.executeUpdate();
conn.commit();

使用时需要注意的问题:

1,如果是用Hibernate的对象来影射数据库操作(save,load..),需要将mapping文件的type="date"改成type="timestamp".

2,如果用Query(session的createQuery和createSQLQuery),在赋值的时候用query.setTimestamp(0, new Date());

?

?

String hql = " from table tb where tb.startdate = :Startdate ";?
Query q = session.createQuery(hql).setString( "Startdate ", sdate);?
修改为:?
String hql = " from table tb where tb.startdate like :Startdate ";?
Query q = session.createQuery(hql).setString( "Startdate ", sdate+ "% ");?

?

分享到:
评论

相关推荐

    hiberante3 注解帮助文档

    hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档

    DAO层中对Hiberante

    在Java的持久化框架中,Hibernate是一个非常流行的ORM(对象关系映射)工具,它允许开发者将数据库操作转化为对Java对象的操作。DAO(Data Access Object)层是软件设计模式中的一个重要概念,主要用于处理数据访问...

    hiberante 源码 配置资料

    3. 数据库交互:Hibernate通过JDBC进行数据库操作,`org.hibernate.engine.jdbc`包下包含了对JDBC的封装。例如,ConnectionProvider负责数据库连接的获取和释放,而StatementExecutor处理SQL执行。 4. 查询机制:...

    spring+mvc+hiberante

    当方法执行时,Spring 自动处理事务的开始、提交或回滚,根据是否有异常发生。 在实际应用中,我们可能还需要配置数据源、日志记录、错误处理、国际化等功能。Spring Boot 是一种快速开发工具,可以简化上述配置,...

    基于web的人事管理系统的设计与实现样本.doc

    该系统采用SSH框架和JSP技术,使用MySQL作为后台数据库管理系统,并使用Struts作为系统的整体架构,Spring负责业务管理,Hiberante负责后台数据库管理。 系统需求分析 在设计人事管理系统之前,需要对企业的需求...

    Hiberante3.jar + API

    Hibernate,作为一个强大的对象关系映射(ORM)框架,是Java开发者在处理数据库操作时的得力助手。本篇将深入探讨Hibernate3.jar及其API,帮助开发者更好地理解和运用这个库。 一、Hibernate3.jar介绍 Hibernate3....

    Struts+Hiberante+Sprint 框架整合

    开发工具:MyEclipse 6....Struts+Spring+Hiberante框架整合的简单登录系统 无需配置任何文件、只需在mysql中创建一个空数据库 如:create database test; 注:mysql数据库用户名:root 密码:root

    hiberante5.0.7安装jar包

    在5.0.7版本中,Hibernate引入了一系列改进和增强,使得它在处理数据库操作时更加高效和便捷。 **一、Hibernate核心组件** 1. **hibernate-core.jar**: 这是Hibernate的核心库,包含了对ORM(对象关系映射)的主要...

    hiberante查询方式使用详解

    在Java世界中,Hibernate是一个非常流行...理解并熟练掌握这些查询方式,将极大地提升你在开发Java应用时对数据库操作的灵活性和效率。在实际项目中,应根据需求选择最合适的查询方法,以实现最佳性能和代码可维护性。

    最新springboot2hiberante5项目

    最新springboot2基础hiberante5完整项目,打包jar,运行jsp,包括后台与前台,拦截器,登录,后台下载就可以使用,注意不是jpa,里面有完整Dao,千万级数据项目分离的代码,为了适合老项目开发特意集成hiberante5....

    Struts2+Hiberante+ajax+Mysql 三级联动

    在实现三级联动时,开发者通常会创建三个相关的数据库表,每个表代表一级、二级和三级分类。然后,通过Hibernate的Criteria或HQL(Hibernate Query Language)来查询数据,Struts2 Action处理Ajax请求并返回JSON格式...

    Hiberante3相关文档

    描述中的“Hiberante3_HQL”提示我们将会涉及到Hibernate查询语言(HQL),它是面向对象的查询语言,允许开发者以类和对象的方式查询数据库。 “Hibernate3_缓存机制”意味着这部分内容将深入探讨Hibernate如何通过...

    Hiberante 有关jar包

    Hibernate Tools是一套全新而且完整的面向Hibernate3的工具集合,它包含了Eclipse插件和Ant编译流程。Hibernate Tools是JBoss Tools的核心组件,所以他也是JBoss Developer Studio的一部分

    hiberante annotations reference.pdf

    指定日期时间字段的类型,支持三种类型:`TemporalType.DATE`(仅日期部分)、`TemporalType.TIME`(仅时间部分)、`TemporalType.TIMESTAMP`(日期和时间部分)。 #### @OneToMany 和 @ManyToOne 分别表示一对多和...

    springmvc hiberante

    Spring MVC 和 Hibernate 是两个在Java Web开发中广泛使用的框架,它们分别是用于构建MVC(Model-View-Controller)架构的Web应用和管理数据库操作的对象关系映射(ORM)工具。在实际项目中,这两个框架的集成能提供...

    Hiberante中的五大核心接口.txt

    这些接口对于Hibernate的正常运行至关重要,它们不仅支持对持久化对象的操作,还能够进行事务控制,是开发人员在使用Hibernate时必须掌握的关键技术点。 #### 二、Session接口 `Session` 接口是Hibernate框架中最...

    hiberante annotations reference_cn

    - `@Temporal`: 用于日期和时间类型的字段,指定其存储类型(TIMESTAMP, DATE, TIME)。 - `@TemporalType`: 配合`@Temporal`定义日期时间类型的存储格式。 - `@Inheritance`: 控制实体类继承时的表策略,如单表...

    Hiberante lib

    Hibernate是一个开源的对象关系映射(ORM)框架,它允许Java开发者使用面向对象的方式来操作数据库,极大地简化了数据库编程。在给定的“Hiberante lib”压缩包中,包含的jar文件是Hibernate框架运行所必需的库。...

    hiberante4.2.3-part2

    hiberante4.2.3-part2

    Hiberante读取BLOB数据类型.

    // 假设byteData是待存入数据库的二进制数据 File tempFile = new File("tempFile"); FileOutputStream fos = new FileOutputStream(tempFile); fos.write(byteData); fos.close(); session.saveOrUpdate...

Global site tag (gtag.js) - Google Analytics