zoukankan      html  css  js  c++  java
  • Hibernate createCriteria查询详解

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

    [java] view plaincopy
     
    1. Criteria crit = sess.createCriteria(Cat.class);  
    2.   
    3. crit.setMaxResults(50);   
    4.   
    5. List cats = crit.list();   

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

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

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

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

    [java] view plaincopy
     
    1. List cats = sess.createCriteria(Cat.class)   
    2.   
    3.     .createCriteria("kittens", "kt")   
    4.   
    5.     .add( Expression.eq("name", "F%") )   
    6.   
    7.     .returnMaps()  
    8.   
    9.     .list();   
    10.   
    11. Iterator iter = cats.iterator();   
    12.   
    13. while ( iter.hasNext())  
    14.   
    15. {     
    16.   
    17.     Map map = (Map) iter.next();   
    18.   
    19.     Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);  
    20.   
    21.     Cat kitten = (Cat) map.get("kt");   
    22.   
    23. }   
    24. 5、动态关联对象获取(Dynamic association fetching) 可以在运行时通过setFetchMode()来改变关联对象自动获取的策略。  
    25. <pre class="java" name="code">List cats = sess.createCriteria(Cat.class)   
    26.   
    27.                 .add( Expression.like("name", "Fritz%") )  
    28.   
    29.                 .setFetchMode("mate", FetchMode.EAGER)   
    30.   
    31.                 .list(); </pre>  
    32.   
    33. 这个查询会通过外连接(outer join)同时获得 mate和kittens。   
    34. 6、根据示例查询(Example queries) net.sf.hibernate.expression.Example类许你从指定的实例创造查询条件。   
    35.   
    36. <pre class="java" name="code">Cat cat = new Cat();   
    37.   
    38. cat.setSex('F');   
    39.   
    40. cat.setColor(Color.BLACK);   
    41.   
    42. List results = session.createCriteria(Cat.class)    
    43.   
    44.                     .add( Example.create(cat) )    
    45.   
    46.                     .list();   
    47. 版本属性,表示符属性和关联都会被忽略。默认情况下,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

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

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

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

  • 相关阅读:
    python运行时参数m的作用
    如何设置.net控件SplitContainer平均分配
    不用安装Oracle客户端
    视频聊天APP
    Hadoop框架
    Shell
    Linux
    java14带参的方法
    java13人机猜拳
    java12类的无参方法
  • 原文地址:https://www.cnblogs.com/whtydn/p/5001135.html
Copyright © 2011-2022 走看看