博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Criteria 和 DetachedCriteria的区别与使用
阅读量:6842 次
发布时间:2019-06-26

本文共 3894 字,大约阅读时间需要 12 分钟。

Criteria 和 DetachedCriteria 的主要区别在于创建的形式不一样, Criteria 是在线的,所 以它是由 Hibernate Session 进行创建的;而 DetachedCriteria 是离线的,创建时无需 Session,DetachedCriteria 提供了 2 个静态方法 fClass(Class) 或 fEntityName(Name) 进行DetachedCriteria 实例的创建。 Spring 的框架提供了getHibernateTemplate ().findByCriteria(detachedCriteria) 方法可以很方便地根据DetachedCriteria 来返回查询结 果。 Criteria 和 DetachedCriteria 均可使用 Criterion 和 Projection 设置查询条件。可以设 置 FetchMode( 联合查询抓取的模式 ) ,设置排序方式。对于 Criteria 还可以设置 FlushModel (冲刷 Session 的方式)和 LockMode (数据库锁模式)。 下面对 Criterion 和 Projection 进行详细说明。 Criterion 是 Criteria 的查询条件。Criteria 提供了 add(Criterion criterion) 方法来 添加查询条件。 Criterion 接口的主要实现包括:  、 Junction 和 SimpleExpression 。而 Junction 的实际使用是它的两个子类 conjunction 和 disjunction ,分别是使用 AND 和  操 作符进行来联结查询条件集合。 Criterion 的实例可以通过 Restrictions 工具类来创建,Restrictions 提供了大量的静态 方法,如 eq (等于)、 ge ()、 between 等来方法的创建 Criterion 查询条件 (SimpleExpression 实例)。除此之外, Restrictions 还提供了方法来创建 conjunction 和 disjunction 实例,通过往该实例的 add(Criteria) 方法来增加查询条件形成一个查询条件集合 。 至于  的创建有所不同,  本身提供了一个静态方法 create(Object entity) ,即根据一个对象(实际使用中一般是映射到数据库的对象)来创建。然后可以设置一些 过滤条件: Example exampleUser =Example.create(u) .ignoreCase() // 忽略大小写 .enableLike(MatchMode.ANYWHERE); // 对 String 类型的属性,无论在那里值在那里都匹配。相当于 %value% Project 主要是让 Criteria 能够进行报表查询,并可以实现分组。 Project 主要有 SimpleProjection 、 ProjectionList 和 Property 三个实现。其中 SimpleProjection 和 ProjectionList 的实例化是由内建的 Projections 来完成,如提供的 avg 、 count 、 max 、 min 、 sum 可以让开发者很容易对某个字段进行统计查询。        Property 是对某个字段进行查询条件的设置,如通过Porperty.forName(“color”).in (new String[]{“black”,”red”,”write”}); 则可以创建一个 Project 实例。通过 criteria 的 add(Project) 方法加入到查询条件中去。     使用 Criteria 进行查询,主要要清晰的是 Hibernate 提供了那些类和方法来满足开发中查 询条件的创建和组装,下面介绍几种用法: 1. 创建一个Criteria 实例 org.hibernate.Criteria接口表示特定持久类的一个查询。Session是 Criteria实例的工厂。 Criteria crit = sess.createCriteria(Cat.class); crit.setMaxResults(50); List  = crit.list(); 2. 限制结果集内容 一个单独的查询条件是org.hibernate.criterion.Criterion 接口的一个实例。 org.hibernate.criterion.Restrictions类 定义了获得某些内置Criterion类型的工厂方法。 List  = sess.createCriteria(Cat.class)     .add( Restrictions.like("name", "Fritz%") )     .add( Restrictions.between("weight", minWeight, maxWeight) )     .list(); 约束可以按逻辑分组。 List  = sess.createCriteria(Cat.class)     .add( Restrictions.like("name", "Fritz%") )     .add( Restrictions.or(         Restrictions.eq( "age", new Integer(0) ),         Restrictions.isNull("age")     ) )     .list(); List cats = sess.createCriteria(Cat.class)     .add( Restrictions.in( "name", new String[] { "Fritz", "", "Pk" } ) )     .add( Restrictions.disjunction()         .add( Restrictions.isNull("age") )         .add( Restrictions.eq("age", new Integer(0) ) )         .add( Restrictions.eq("age", new Integer(1) ) )         .add( Restrictions.eq("age", new Integer(2) ) )     ) )     .list(); Hibernate提供了相当多的内置criterion类型(Restrictions 子类), 但是尤其有用的是可以允许你直接使用。 List cats = sess.createCriteria(Cat.class)     .add( Restrictions.("lower({alias}.name) like lower(?)", "Fritz%",Hibernate.STRING) )     .list(); {alias}占位符应当被替换为被查询实体的列别名。 Property实例是获得一个条件的另外一种途径。你可以通过调用Property.forName() 创建一个Property。 Property age = Property.forName("age"); List cats = sess.createCriteria(Cat.class)     .add( Restrictions.disjunction()         .add( age.isNull() )         .add( age.eq( new Integer(0) ) )         .add( age.eq( new Integer(1) ) )         .add( age.eq( new Integer(2) ) )     ) )     .add( Property.forName("name").in( new String[] { "Fritz", "", "Pk" } ) )     .list(); 3. 结果集排序 你可以使用org.hibernate.criterion.Order来为查询结果排序。 List cats = sess.createCriteria(Cat.class)     .add( Restrictions.like("name", "F%")     .addOrder( Order.asc("name") )     .addOrder( Order.desc("age") )     .setMaxResults(50)     .list(); List cats = sess.createCriteria(Cat.class)     .add( Property.forName("name").like("F%") )     .addOrder( Property.forName("name").asc() )     .addOrder( Property.forName("age").desc() )     .setMaxResults(50)     .list(); 相关:

转载地址:http://pmbul.baihongyu.com/

你可能感兴趣的文章
yanf4j 1.0-stable的一个压测报告
查看>>
Square 技术团队的开源其 Vim 配置文件
查看>>
《Java编码指南:编写安全可靠程序的75条建议》—— 指南6:正确地编码或转义输出...
查看>>
阿里NASA的液冷黑科技 | 彻底激活未来AI大脑超能力
查看>>
stack源码分析
查看>>
Java内存溢出(OOM)异常完全指南
查看>>
云计算十字真言及其在小博无线的实践
查看>>
用一生回味的经典语录
查看>>
你的命运不是一头骡子
查看>>
排序算法之鸽巢排序
查看>>
Appium移动自动化框架
查看>>
无线动态化解决方案总结:从WeApp到Weex
查看>>
CentOS上安装Bugzilla 4.5.2
查看>>
嵌入式 RTP通话:视频流(H.264)的传输
查看>>
参数的排列组合2
查看>>
struts2中ognl标签详解
查看>>
.NET中Flags枚举的使用
查看>>
【Python之旅】第八篇:开发监控软件的思想与流程
查看>>
KVM虚拟机克隆
查看>>
XenApp / XenDesktop 7.6 初体验二 配置计算机目录和交付组
查看>>