- 浏览: 413468 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
skying007:
...
Mysql coalesce() 函数认识和用法 -
kchiu:
关于这个心跳的发送和接收 晚上全是the fuccking s ...
socket心跳检测 -
bjsq618:
你的想法在大的物流公司已经实现了,只不过他们使用是GPS定位
ddd -
jiaguwen123:
2,AuthenticationHandler类的写法
pa ...
xfire客户端 -
sornor:
总结的不错哟!
Java中的函数yield(),sleep()和wait()的区别
Hibernate3支持DetachedCriteria,这是一个非常有意义的特性!我们知道,在常规的Web编程中,有大量的动态条件查询,即用户在网页上面自由选择某些条件,程序根据用户的选择条件,动态生成SQL语句,进行查询。
针对这种需求,对于分层应用程序来说,Web层需要传递一个查询的条件列表给业务层对象,业务层对象获得这个条件列表之后,然后依次取出条件,构造查询语句。这里的一个难点是条件列表用什么来构造?传统上使用Map,但是这种方式缺陷很大,Map可以传递的信息非常有限,只能传递name和value,无法传递究竟要做怎样的条件运算,究竟是大于,小于,like,还是其它的什么,业务层对象必须确切掌握每条entry的隐含条件。因此一旦隐含条件改变,业务层对象的查询构造算法必须相应修改,但是这种查询条件的改变是隐式约定的,而不是程序代码约束的,因此非常容易出错。
DetachedCriteria可以解决这个问题,即在web层,程序员使用DetachedCriteria来构造查询条件,然后将这个DetachedCriteria作为方法调用参数传递给业务层对象。而业务层对象获得DetachedCriteria之后,可以在session范围内直接构造Criteria,进行查询。就此,查询语句的构造完全被搬离到web层实现,而业务层则只负责完成持久化和查询的封装即可,与查询条件构造完全解耦,非常完美!这恐怕也是以前很多企图在web层代码中构造HQL语句的人想实现的梦想吧!
示例代码片段如下:
web层程序构造查询条件:
java代码:
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class); detachedCriteria.add(Restrictions.eq("name", "department")).createAlias("employees", "e").add(Restrictions.gt(("e.age"), new Integer(20))); |
Department和Employee是一对多关联,查询条件为:
名称是“department”开发部门;
部门里面的雇员年龄大于20岁;
业务层对象使用该条件执行查询:
java代码:
detachedCriteria.getExecutableCriteria(session).list(); |
最大的意义在于,业务层代码是固定不变的,所有查询条件的构造都在web层完成,业务层只负责在session内执行之。这样代码就可放之四海而皆准,都无须修改了。
然而Spring和Hibernate3的DetachedCriteria有不兼容的问题,因此在Spring环境下面使用Hibernate3需要注意:
Spring的HibernateTemplate提供了Hibernate的完美封装,即通过匿名类实现回调,来保证Session的自动资源管理和事务的管理。其中核心方法是:
java代码:
HibernateTemplate.execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { .... } } |
回调方法提供了session作为参数,有了session,就可以自由的使用Hibernate API编程了。使用了spring的之后,代码修改如下:
web层代码:
java代码:
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class); detachedCriteria.createAlias("employees", "e").add(Restrictions.eq("name", "department")).add(Restrictions.gt(("e.age"), new Integer(20))); departmentManager.findByCriteria(detachedCriteria); |
构造detachedCriteria,作为参数传递给departmentManager
业务层代码使用spring,DepartmentManager的findByCriteria如下:
java代码:
public List findByCriteria(final DetachedCriteria detachedCriteria) { return (List) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = detachedCriteria.getExecutableCriteria(session); return criteria.list(); } }); } |
实际上也就是:
java代码:
Criteria criteria = detachedCriteria.getExecutableCriteria(session); return criteria.list(); |
而已
但是该程序代码执行,会抛出强制类型转换异常!
我跟踪了一下spring和Hibernate源代码,原因如下:
spring的HibernateTemplate的execute方法提供的回调接口具有Session作为参数,但是实际上,默认情况下,HibernateTemplate传递给回调接口的session并不是org.hibernate.impl.SessionImpl类,而是SessionImpl类的一个Proxy类。之所以替换成为一个Proxy类,HibernateTemplate的注释说明,Proxy提供了一些额外的功能,包括自动设置Cachable,Transaction的超时时间,Session资源的更积极的关闭等等。
java代码:
private boolean exposeNativeSession = false; ... |
execute方法内部:
Session sessionToExpose = (exposeNativeSession ? session : createSessionProxy(session)); |
但是遗憾的是,Hibernate的DetachedCriteria的setExecutableCriteria方法却要求将session参数强制转为SessionImpl,但是spring传过来的却是一个Proxy类,因此就报错了。
java代码:
public Criteria getExecutableCriteria(Session session) { impl.setSession( (SessionImpl) session ); // 要求SessionImpl,Spring传递的是Proxy return impl; } |
解决方法,禁止Spring的HibernateTemplate传递Proxy类,强制要求它传递真实的SessionImpl类,即给exexute方法增加一个参数,提供参数为true,如下:
java代码:
public List findByCriteria(final DetachedCriteria detachedCriteria) { return (List) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = detachedCriteria.getExecutableCriteria(session); return criteria.list(); } }, true); } |
发表评论
-
入门 05 - Query接口
2012-09-05 08:13 1638入门 05 - Query接口 我 ... -
Hibernate 5种查询方式代码示例
2011-08-13 09:52 1706package com.cstp.hibernate; im ... -
Java Hibernate Criteria 用法
2010-11-07 23:43 507915.1. 创建一个Criteria 实例org.hibern ... -
hibernate技巧 封装查询结果
2010-11-07 23:30 1249hibernate技巧 封装查询结果 将hibernate 查 ... -
hibernate调用数据库自定义函数
2010-10-31 17:31 1721本文使用的是Oracle9i数据库,hibernate3.0, ... -
HibernateTemplate 的 find方法使用
2010-10-27 22:04 2295一、find(String queryString); ... -
hibernate分组查询
2010-10-26 21:54 1642private static final Str ... -
Hibernate Criteria
2010-10-10 21:58 987Hibernate QBC查询 QBC查询: ... -
论述Hibernate中抓取策略
2010-10-10 21:27 1313Hibernate抓取策略(fetch ... -
hibernate 中对象操作中evict方法和clear方法的区别
2010-09-14 10:11 1262session.evict(obj),会把指定的缓冲对象进行清 ... -
Hibernate三种状态的区分
2010-09-14 10:02 963Hibernate的对象有3种状态,分别为:瞬时态(Trans ... -
hibernate查询多对多数据范例
2010-09-03 16:38 1066public class StuDao<T> ex ... -
hibernate生成数据库表
2010-08-19 08:22 4136import org.hibernate.cfg.Config ... -
hibernate二级缓存
2010-08-19 07:56 1113二级缓存也称进程级的缓存或SessionFactory级的缓存 ... -
hibernate一级缓存
2010-08-18 23:11 1255一级缓存很短和session的生命周期一致,一级缓存也叫ses ... -
hibernate向MYSQL插入数据的乱码问题
2010-08-17 21:55 1282向数据库插入数据的时候出现乱码,解决办法: 一、数据库连接串 ... -
composite-id 学习
2010-08-15 17:10 1292组件作为联合标识符,必须满足: 它必须实现java.io.Se ... -
hibernate存储过程调用
2010-08-12 17:28 1600听说Hibenate3可以在执行 ... -
Hibernate对视图的操作
2010-08-12 17:08 1258Hibernate对视图进行操作时和对普通的表有些不同,下面就 ... -
findMsgFluxByCp备忘
2010-08-12 14:21 899public List<MsgFlux> fin ...
相关推荐
**Hibernate 框架及其DetachedCriteria操作详解** Hibernate 是一个强大的Java持久化框架,它极大地简化了数据库操作,使得开发者能够用面向对象的方式处理数据库事务。本篇将深入探讨Hibernate中的...
在Java的持久化框架Hibernate中,DetachedCriteria是一个强大的查询工具,它允许我们在不与Session交互的情况下构建查询条件。然而,DetachedCriteria在处理复杂的关联查询,尤其是涉及到表连接(JOIN)时,可能存在...
《Hibernate3中文文档》是Java开发领域中一份重要的参考资料,主要涵盖了Hibernate3框架的各种特性和用法。Hibernate作为一款开源的对象关系映射(ORM)框架,极大地简化了Java应用程序对数据库的操作,使得开发者...
10. **多对一、一对多、多对多关联映射**:Hibernate3支持多种关联关系的映射,包括单向、双向、级联操作等,使得数据库关系模型能够完整地映射到对象模型。 通过这个"hibernate3.zip"压缩包,你可以获取到完整的...
《Hibernate3使用手册》是Java开发领域中一本重要的参考资料,主要涵盖了如何利用Hibernate3这个流行的持久化框架进行数据库操作的相关知识。Hibernate3作为Java对象关系映射(ORM)工具的代表,极大地简化了数据库...
在查询语言上,Hibernate支持HQL(Hibernate Query Language),这是一种面向对象的查询语言,类似于SQL但操作的是对象而非表格。此外,`Criteria` API提供了一种类型安全的方式来构建动态查询,而`DetachedCriteria...
- Hibernate 3支持JTA(Java Transaction API)和JDBC事务管理。开发者可以通过Session的`beginTransaction()`, `commit()`, `rollback()`等方法进行事务控制。 10. **缓存机制**: - Hibernate 3引入了两级缓存...
3. **实体类和映射文件**:理解实体类的定义,以及如何使用Hibernate注解或XML映射文件将这些类与数据库表关联。比如@Entity、@Table、@Id等注解的使用。 4. **CRUD操作**:了解如何使用Hibernate进行创建(Create)...
5. **实体类和注解**:Hibernate3支持使用Java 5以上的注解来标注实体类,如@Entity表示该类为数据库表的映射,@Id表示主键,@GeneratedValue用于自动生成主键等。 6. **二级缓存**:为了提高性能,Hibernate3引入...
3. **实体类(Entities)**:在Hibernate中,业务对象被定义为Java类,这些类被称为实体类,它们的实例对应数据库中的记录。实体类需要使用注解或XML文件来声明与数据库表的映射关系。 4. **注解驱动的映射**:...
在Hibernate 3.2版本中,这个开源的对象关系映射(ORM)框架提供了一系列重要的改进和增强,包括性能优化、新功能的添加以及对JPA规范的支持。以下将详细介绍其中的关键知识点: 1. **对象关系映射基础**:...
15. **版本控制**:Hibernate 3相较于早期版本,可能包含更多改进和新特性,如更完善的 Criteria API 和增强的HQL支持。 **文件名称列表解析** "html_single"这个文件名可能表示文档是以单个HTML文件的形式提供的...
Hibernate支持多种数据库,如MySQL、Oracle、PostgreSQL等,通过方言(Dialect)类适应不同数据库的SQL语法差异。 **10. JPA支持** Hibernate 5.1.10也支持Java Persistence API (JPA),这是Java EE规范的一部分,...
3. **Criteria API**:在Hibernate 3.6.1中,Criteria API提供了一种类型安全的方式来执行动态查询,无需编写SQL。`org.hibernate.criterion`包下的类,如`Criterion`, `DetachedCriteria`等,用于构建查询条件。这...
- `hibernate3.jar`:核心库,包含了所有基本的Hibernate功能。 - `hibernate-annotations.jar`:提供了注解支持,使得在实体类上可以直接使用注解进行配置。 - `hibernate-commons-annotations.jar`:用于处理注解...
3. **Criteria查询**: 提供一种面向对象的查询方式,通过Criteria和DetachedCriteria构建查询条件。 4. ** Criteria API的Join操作**: 支持多表查询,包括内连接(inner join)、左连接(left join)等。 5. **...
3. **Criteria查询**:Hibernate提供了一种动态构建SQL查询的方法,即Criteria API,这在处理复杂查询时非常有用。通过`Criteria`和`DetachedCriteria`接口,可以在运行时构造查询条件。 4. **HQL(Hibernate Query...
- DetachedCriteria:支持离线查询,可以在不开启Session的情况下构造查询条件。 7. Criteria 查询示例 ```java Criteria criteria = session.createCriteria(User.class); criteria.add(Restrictions.eq(...
10. **实体关系**:Hibernate 支持一对一、一对多、多对一、多对多等多种关系映射,如`@OneToOne`、`@OneToMany`、`@ManyToOne`、`@ManyToMany`。 11. **懒加载与立即加载**:Hibernate 提供了懒加载(Lazy Loading...
6. Native SQL:当需要充分利用数据库特定特性时,可以使用原生SQL查询,Hibernate提供了支持。 7. 一对多、多对一、多对多关系映射:这部分会讲解如何处理不同类型的关联关系,包括集合的映射和懒加载。 8. 私有...