Hibernate createCriteria查詢詳解


本文轉載自 : http://penghao122.javaeye.com/blog/80794 1、創建一個Criteria實例 net.sf.hibernate.Criteria這個接口代表對一個特定的持久化類的查詢。Session是用來制造Criteria實例的工廠。

[java]  view plain copy
 
  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 plain copy
 
  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 plain copy
 
  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 plain copy
 
  1. 有很多預制的條件類型(Expression的子類)。有一個特別有用,可以讓你直接嵌入SQL。  
[java]  view plain copy
 
  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 plain copy
 
  1.    
  2. 其中的{alias}是一個占位符,它將會被所查詢實體的行別名所替代。                                   
[csharp]  view plain copy
 
  1. (原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)   
[csharp]  view plain copy
 
  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 plain copy
 
  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 plain copy
 
  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();


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM