本文转载自 : http://penghao122.javaeye.com/blog/80794 1、创建一个Criteria实例 net.sf.hibernate.Criteria这个接口代表对一个特定的持久化类的查询。Session是用来制造Criteria实例的工厂。

  1. Criteria crit = sess.createCriteria(Cat.class);
  2. crit.setMaxResults(50);
  3. List cats = crit.list();

2、缩小结果集范围 一个查询条件(Criterion)是net.sf.hibernate.expression.Criterion接口的一个实例。类

net.sf.hibernate.expression.Expression定义了获得一些内置的Criterion类型。

  1. List cats = sess.createCriteria(Cat.class)
  2. .add( Expression.like("name", "Fritz%") )
  3. .add( Expression.between("weight", minWeight, maxWeight))
  4. .list();
  5. 表达式(Expressions)可以按照逻辑分组.
  1. List cats = sess.createCriteria(Cat.class)
  2. .add( Expression.like("name", "Fritz%") )
  3. .add( Expression.or( Expression.eq( "age", new Integer(0) ), Expression.isNull("age")))
  4. .list();
  5. List cats = sess.createCriteria(Cat.class)
  6. .add( Expression.in( "name",new String[]{"Fritz","Izi","Pk"}))
  7. .add( Expression.disjunction()
  8. .add( Expression.isNull("age") )
  9. .add( Expression.eq("age", new Integer(0) ) )
  10. .add( Expression.eq("age", new Integer(1) ) )
  11. .add( Expression.eq("age", new Integer(2) ) ) ) )
  12. .list();
  1. 有很多预制的条件类型(Expression的子类)。有一个特别有用,可以让你直接嵌入SQL。
  1. List cats = sess.createCriteria(Cat.class)
  2. .add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING))
  3. .list();
  1. 其中的{alias}是一个占位符,它将会被所查询实体的行别名所替代。
  1. (原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)
  1. 3、对结果排序 可以使用net.sf.hibernate.expression.Order对结果集排序. <pre class="java" name="code">List cats = sess.createCriteria(Cat.class)
  2. .add( Expression.like("name", "F%")
  3. .addOrder( Order.asc("name"))
  4. .addOrder( Order.desc("age"))
  5. .setMaxResults(50)
  6. .list(); </pre>
  7. 4、关联(Associations) 你可以在关联之间使用createCriteria(),很容易地在存在关系的实体之间指定约束。
  8. <pre class="java" name="code">List cats = sess.createCriteria(Cat.class)
  9. .add( Expression.like("name", "F%")
  10. .createCriteria("kittens")
  11. .add( Expression.like("name","F%")
  12. .list(); </pre>
  13. 注意,第二个createCriteria()返回一个Criteria的新实例,指向kittens集合类的元素。 下面的替代形式在特定情况下有用。
  14. <pre class="csharp" name="code">List cats = sess.createCriteria(Cat.class)
  15. .createAlias("kittens", "kt")
  16. .createAlias("mate", "mt")
  17. .add(Expression.eqProperty("kt.name", "mt.name"))
  18. .list();</pre>
  19. (createAlias())并不会创建一个Criteria的新实例。) 请注意,前面两个查询中Cat实例所持有的kittens集合类并没有通过criteria预先过滤

!如果你希望只返回满足条件的kittens,你必须使用returnMaps()。

  1. List cats = sess.createCriteria(Cat.class)
  2. .createCriteria("kittens", "kt")
  3. .add( Expression.eq("name", "F%") )
  4. .returnMaps()
  5. .list();
  6. Iterator iter = cats.iterator();
  7. while ( iter.hasNext())
  8. {
  9. Map map = (Map) iter.next();
  10. Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);
  11. Cat kitten = (Cat) map.get("kt");
  12. }
  13. 5、动态关联对象获取(Dynamic association fetching) 可以在运行时通过setFetchMode()来改变关联对象自动获取的策略。
  14. <pre class="java" name="code">List cats = sess.createCriteria(Cat.class)
  15. .add( Expression.like("name", "Fritz%") )
  16. .setFetchMode("mate", FetchMode.EAGER)
  17. .list(); </pre>
  18. 这个查询会通过外连接(outer join)同时获得 mate和kittens。
  19. 6、根据示例查询(Example queries) net.sf.hibernate.expression.Example类许你从指定的实例创造查询条件。
  20. <pre class="java" name="code">Cat cat = new Cat();
  21. cat.setSex('F');
  22. cat.setColor(Color.BLACK);
  23. List results = session.createCriteria(Cat.class)
  24. .add( Example.create(cat) )
  25. .list();
  26. 版本属性,表示符属性和关联都会被忽略。默认情况下,null值的属性也被排除在外。 You can adjust how the Example is applied. 你可</pre>

以调整示例(Example)如何应用。 Example example = Example.create(cat) .excludeZeroes() //exclude zero valued properties

.excludeProperty("color") //exclude the property named "color" .ignoreCase() //perform case insensitive string comparisons

.enableLike(); //use like for string comparisons

  1. List results = session.createCriteria(Cat.class)
  2. .add(example)
  3. .list();
  4. 你甚至可以用示例对关联对象建立criteria。

List results = session.createCriteria(Cat.class) .add(Example.create(cat) )

.createCriteria("mate") .add(Example.create(cat.getMate())) .list();

Hibernate createCriteria查询详解的更多相关文章

  1. 分享知识-快乐自己:Hibernate 中Criteria Query查询详解

    1):Hibernate 中Criteria Query查询详解 当查询数据时,人们往往需要设置查询条件.在SQL或HQL语句中,查询条件常常放在where子句中. 此外,Hibernate还支持Cr ...

  2. Hibernate Session & Transaction详解

    Hibernate Session & Transaction详解 HIbernate中的Session Session是JAVA应用程序和Hibernate进行交互时使用的主要接口,它也是持 ...

  3. hibernate缓存机制详解

    hiberante面试题—hibernate缓存机制详解   这是面试中经常问到的一个问题,可以按照我的思路回答,准你回答得很完美.首先说下Hibernate缓存的作用(即为什么要用缓存机制),然后再 ...

  4. ElasticSearch第四步-查询详解

    ElasticSearch系列学习 ElasticSearch第一步-环境配置 ElasticSearch第二步-CRUD之Sense ElasticSearch第三步-中文分词 ElasticSea ...

  5. Solr安装入门、查询详解

    Solr安装入门:http://www.importnew.com/12607.html 查询详解:http://www.360doc.com/content/14/0306/18/203871_35 ...

  6. ThinkPHP视图查询详解

    ThinkPHP视图查询详解 参考http://www.jb51.net/article/51674.htm   这篇文章主要介绍了ThinkPHP视图查询,需要的朋友可以参考下     ThinkP ...

  7. MySQL简单查询详解-单表查询

    MySQL简单查询详解-单表查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询的执行路径 一条SQL查询语句的执行过程大致如下图所示: 1>.客户端和服务端通过my ...

  8. Lucene系列六:Lucene搜索详解(Lucene搜索流程详解、搜索核心API详解、基本查询详解、QueryParser详解)

    一.搜索流程详解 1. 先看一下Lucene的架构图 由图可知搜索的过程如下: 用户输入搜索的关键字.对关键字进行分词.根据分词结果去索引库里面找到对应的文章id.根据文章id找到对应的文章 2. L ...

  9. (转)Mysql 多表查询详解

    MySQL 多表查询详解 一.前言  二.示例 三.注意事项 一.前言  上篇讲到mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有 ...

随机推荐

  1. vue.js入门(3)——组件通信

    5.2 组件通信 尽管子组件可以用this.$parent访问它的父组件及其父链上任意的实例,不过子组件应当避免直接依赖父组件的数据,尽量显式地使用 props 传递数据.另外,在子组件中修改父组件的 ...

  2. Oracle 正则表达式函数-REGEXP_REPLACE 使用例子

    原文在这: 戳 REGEXP_REPLACE 6个参数 第一个是输入的字符串 第二个是正则表达式 第三个是替换的字符 第四个是标识从第几个字符开始正则表达式匹配.(默认为1) 第五个是标识第几个匹配组 ...

  3. IIS7 应用程序池设置成 经典 v2.0

    HTTP 错误 500.21 - Internal Server Error 处理程序“PageHandlerFactory-Integrated”在其模块列表中有一个错误模块“ManagedPipe ...

  4. android cocos2d-x for Android安装和学习笔记(请用adt-bundle21.1或以上导入)

    引用:http://weimingtom.iteye.com/blog/1483566 (20121108)注意:这篇文章用cdt编译ndk工程的内容已过时(现在可以用adt-bundle,避免配置繁 ...

  5. Windows Azure 如何学习Azure

    通过上一篇博文可以得知,Azure其实是个平台,上面跑的服务五花八门,可以相互分开使用,同时也可以相互结合. 那我们应该如何来学习Azure呢? 其实有很多种选择,正所谓条条大路通罗马, 官方的tra ...

  6. POJ 2195:Going Home(最小费用最大流)

    http://poj.org/problem?id=2195 题意:有一个地图里面有N个人和N个家,每走一格的花费是1,问让这N个人分别到这N个家的最小花费是多少. 思路:通过这个题目学了最小费用最大 ...

  7. Python Locust性能测试框架实践

    [本文出自天外归云的博客园] Locust的介绍 Locust是一个python的性能测试工具,你可以通过写python脚本的方式来对web接口进行负载测试. Locust的安装 首先你要安装pyth ...

  8. Android官方数据绑定框架DataBinding

    数据绑定框架给我们带来了更大的方便性,以前我们可能需要在Activity里写很多的findViewById,烦人的代码也增加了我们代码的耦合性,现在我们马上就可以抛弃那么多的findViewById. ...

  9. Less 使用指南

    简而言之 Less是为了简化css http://less.bootcss.com/features/ 以上链接是Less中文网站,里面有对Less的详细介绍. 一下写在使用中遇到的问题: 1.下载L ...

  10. C/C++ 宏中的 #、#@、##的作用

    宏中的# 功能是将其后面的宏参数进行字符串化操作(Stringizing operator), 简单说就是在它引用的宏变量的左右各加上一个双引号. #define STRING(x) #x 下面二条语 ...