方法 | 說明 |
Restrictions.eq | 等於 |
Restrictions.allEq | 使用Map,使用key/value進行多個等於的比對 |
Restrictions.gt | 大於 > |
Restrictions.ge | 大於等於 >= |
Restrictions.lt | 小於 < |
Restrictions.le | 小於等於 <= |
Restrictions.between | 對應SQL的BETWEEN子句 |
Restrictions.like | 對應SQL的LIKE子句 |
Restrictions.in | 對應SQL的in子句 |
Restrictions.and | and關係 |
Restrictions.or | or關係 |
Criteria crit = sess.createCriteria(Cat.class); crit.setMaxResults(50); List cats = crit.list();
List cats = sess.createCriteria(Cat.class) .add( Restrictions.like("name", "Fritz%") ) .add( Restrictions.between("weight", minWeight, maxWeight) ) .list();
List cats = 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", "Izi", "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();
List cats = sess.createCriteria(Cat.class) .add( Restrictions.sql("lower({alias}.name) like lower(?)", "Fritz%", Hibernate.STRING) ) .list();
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", "Izi", "Pk" } ) ) .list();
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();
List cats = sess.createCriteria(Cat. class) .add( Restrictions.like( "name", "F%") .createCriteria( "kittens") .add( Restrictions.like( "name", "F%") .list();注意第二個 createCriteria()返回一個新的 Criteria實例,該實例引用kittens 集合中的元素。
List cats = sess.createCriteria(Cat. class) .createAlias( "kittens", "kt") .createAlias( "mate", "mt") .add( Restrictions.eqProperty( "kt.name", "mt.name") ) .list();
List cats = sess.createCriteria(Cat. class) .createCriteria( "kittens", "kt") .add( Restrictions.eq( "name", "F%") ) .returnMaps() .list(); Iterator iter = cats.iterator(); while ( iter.hasNext() ) { Map map = (Map) iter.next(); Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS); Cat kitten = (Cat) map.get( "kt"); }5. 動態關聯抓取
List cats = sess.createCriteria(Cat. class) .add( Restrictions.like( "name", "Fritz%") ) .setFetchMode( "mate", FetchMode.EAGER) .setFetchMode( "kittens", FetchMode.EAGER) .list();這個查詢能夠經過外鏈接抓取mate和kittens。
Cat cat = new Cat(); cat.setSex( 'F'); cat.setColor(Color.BLACK); List results = session.createCriteria(Cat. class) .add( Example.create(cat) ) .list();版本屬性、標識符和關聯被忽略。默認狀況下值爲null的屬性將被排除。
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 List results = session.createCriteria(Cat. class) .add(example) .list();
List results = session.createCriteria(Cat. class) .add( Example.create(cat) ) .createCriteria( "mate") .add( Example.create( cat.getMate() ) ) .list();7. 投影(Projections)、聚合(aggregation)和分組(grouping)
List results = session.createCriteria(Cat. class) .setProjection( Projections.rowCount() ) .add( Restrictions.eq( "color", Color.BLACK) ) .list(); List results = session.createCriteria(Cat. class) .setProjection( Projections.projectionList() .add( Projections.rowCount() ) .add( Projections.avg( "weight") ) .add( Projections.max( "weight") ) .add( Projections.groupProperty( "color") ) ) .list();在一個條件查詢中沒有必要顯式的使用 "group by" 。某些投影類型就是被定義爲 分組投影,他
們也出如今SQL的group by子句中。
能夠選擇把一個別名指派給一個投影,這樣可使投影值被約束或排序所引用。下面是兩種不一樣的
實現方式: html
List results = session.createCriteria(Cat. class) .setProjection( Projections.alias( Projections.groupProperty( "color"), "colr" ) ) .addOrder( Order.asc( "colr") ) .list();
List results = session.createCriteria(Cat. class) .setProjection( Projections.groupProperty( "color").as( "colr") ) .addOrder( Order.asc( "colr") ) .list();
alias()和as()方法簡便的將一個投影實例包裝到另一個 別名的Projection實例中。簡而言之,
當你添加一個投影到一個投影列表中時 你能夠爲它指定一個別名:
java
List results = session.createCriteria(Cat. class) .setProjection( Projections.projectionList() .add( Projections.rowCount(), "catCountByColor" ) .add( Projections.avg( "weight"), "avgWeight" ) .add( Projections.max( "weight"), "maxWeight" ) .add( Projections.groupProperty( "color"), "color" ) ) .addOrder( Order.desc( "catCountByColor") ) .addOrder( Order.desc( "avgWeight") ) .list(); List results = session.createCriteria(Domestic. class, "cat") .createAlias( "kittens", "kit") .setProjection( Projections.projectionList() .add( Projections.property( "cat.name"), "catName" ) .add( Projections.property( "kit.name"), "kitName" ) ) .addOrder( Order.asc( "catName") ) .addOrder( Order.asc( "kitName") ) .list();
List results = session.createCriteria(Cat. class) .setProjection( Property.forName( "name") ) .add( Property.forName( "color").eq(Color.BLACK) ) .list(); List results = session.createCriteria(Cat. class) .setProjection( Projections.projectionList() .add( Projections.rowCount().as( "catCountByColor") ) .add( Property.forName( "weight").avg().as( "avgWeight") ) .add( Property.forName( "weight").max().as( "maxWeight") ) .add( Property.forName( "color").group().as( "color" ) ) .addOrder( Order.desc( "catCountByColor") ) .addOrder( Order.desc( "avgWeight") ) .list();
DetachedCriteria類使你在一個session範圍以外建立一個查詢,而且可使用任意的 Session來執行它。
sql
DetachedCriteria query = DetachedCriteria.forClass(Cat. class) .add( Property.forName( "sex").eq( 'F') ); //建立一個Session Session session = .; Transaction txn = session.beginTransaction(); List results = query.getExecutableCriteria(session).setMaxResults(100).list(); txn.commit(); session.close();
DetachedCriteria也能夠用以表示子查詢。條件實例包含子查詢能夠經過 Subqueries或者
Property得到。 數據庫
DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat. class) .setProjection( Property.forName( "weight").avg() ); session.createCriteria(Cat. class) .add( Property.forName( "weight).gt(avgWeight) ) .list(); DetachedCriteria weights = DetachedCriteria.forClass(Cat.class) .setProjection( Property.forName("weight ") ); session.createCriteria(Cat.class) .add( Subqueries.geAll("weight ", weights) ) .list();
相互關聯的子查詢也是有可能的: session
DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat. class, "cat2") .setProjection( Property.forName( "weight").avg() ) .add( Property.forName( "cat2.sex").eqProperty( "cat.sex") ); session.createCriteria(Cat. class, "cat") .add( Property.forName( "weight").gt(avgWeightForSex) ) .list();