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 注解帮助文档
在Java的持久化框架中,Hibernate是一个非常流行的ORM(对象关系映射)工具,它允许开发者将数据库操作转化为对Java对象的操作。DAO(Data Access Object)层是软件设计模式中的一个重要概念,主要用于处理数据访问...
3. 数据库交互:Hibernate通过JDBC进行数据库操作,`org.hibernate.engine.jdbc`包下包含了对JDBC的封装。例如,ConnectionProvider负责数据库连接的获取和释放,而StatementExecutor处理SQL执行。 4. 查询机制:...
当方法执行时,Spring 自动处理事务的开始、提交或回滚,根据是否有异常发生。 在实际应用中,我们可能还需要配置数据源、日志记录、错误处理、国际化等功能。Spring Boot 是一种快速开发工具,可以简化上述配置,...
该系统采用SSH框架和JSP技术,使用MySQL作为后台数据库管理系统,并使用Struts作为系统的整体架构,Spring负责业务管理,Hiberante负责后台数据库管理。 系统需求分析 在设计人事管理系统之前,需要对企业的需求...
Hibernate,作为一个强大的对象关系映射(ORM)框架,是Java开发者在处理数据库操作时的得力助手。本篇将深入探讨Hibernate3.jar及其API,帮助开发者更好地理解和运用这个库。 一、Hibernate3.jar介绍 Hibernate3....
开发工具:MyEclipse 6....Struts+Spring+Hiberante框架整合的简单登录系统 无需配置任何文件、只需在mysql中创建一个空数据库 如:create database test; 注:mysql数据库用户名:root 密码:root
在5.0.7版本中,Hibernate引入了一系列改进和增强,使得它在处理数据库操作时更加高效和便捷。 **一、Hibernate核心组件** 1. **hibernate-core.jar**: 这是Hibernate的核心库,包含了对ORM(对象关系映射)的主要...
在Java世界中,Hibernate是一个非常流行...理解并熟练掌握这些查询方式,将极大地提升你在开发Java应用时对数据库操作的灵活性和效率。在实际项目中,应根据需求选择最合适的查询方法,以实现最佳性能和代码可维护性。
最新springboot2基础hiberante5完整项目,打包jar,运行jsp,包括后台与前台,拦截器,登录,后台下载就可以使用,注意不是jpa,里面有完整Dao,千万级数据项目分离的代码,为了适合老项目开发特意集成hiberante5....
在实现三级联动时,开发者通常会创建三个相关的数据库表,每个表代表一级、二级和三级分类。然后,通过Hibernate的Criteria或HQL(Hibernate Query Language)来查询数据,Struts2 Action处理Ajax请求并返回JSON格式...
描述中的“Hiberante3_HQL”提示我们将会涉及到Hibernate查询语言(HQL),它是面向对象的查询语言,允许开发者以类和对象的方式查询数据库。 “Hibernate3_缓存机制”意味着这部分内容将深入探讨Hibernate如何通过...
Hibernate Tools是一套全新而且完整的面向Hibernate3的工具集合,它包含了Eclipse插件和Ant编译流程。Hibernate Tools是JBoss Tools的核心组件,所以他也是JBoss Developer Studio的一部分
指定日期时间字段的类型,支持三种类型:`TemporalType.DATE`(仅日期部分)、`TemporalType.TIME`(仅时间部分)、`TemporalType.TIMESTAMP`(日期和时间部分)。 #### @OneToMany 和 @ManyToOne 分别表示一对多和...
Spring MVC 和 Hibernate 是两个在Java Web开发中广泛使用的框架,它们分别是用于构建MVC(Model-View-Controller)架构的Web应用和管理数据库操作的对象关系映射(ORM)工具。在实际项目中,这两个框架的集成能提供...
这些接口对于Hibernate的正常运行至关重要,它们不仅支持对持久化对象的操作,还能够进行事务控制,是开发人员在使用Hibernate时必须掌握的关键技术点。 #### 二、Session接口 `Session` 接口是Hibernate框架中最...
- `@Temporal`: 用于日期和时间类型的字段,指定其存储类型(TIMESTAMP, DATE, TIME)。 - `@TemporalType`: 配合`@Temporal`定义日期时间类型的存储格式。 - `@Inheritance`: 控制实体类继承时的表策略,如单表...
Hibernate是一个开源的对象关系映射(ORM)框架,它允许Java开发者使用面向对象的方式来操作数据库,极大地简化了数据库编程。在给定的“Hiberante lib”压缩包中,包含的jar文件是Hibernate框架运行所必需的库。...
hiberante4.2.3-part2
// 假设byteData是待存入数据库的二进制数据 File tempFile = new File("tempFile"); FileOutputStream fos = new FileOutputStream(tempFile); fos.write(byteData); fos.close(); session.saveOrUpdate...