1、创建一个Criteria实例
net.sf.hibernate.Criteria这个接口代表对一个特定的持久化类的查询。Session是用来制造Criteria实例的工厂。
2、缩小结果集范围
一个查询条件(Criterion)是net.sf.hibernate.expression.Criterion接口的一个实例。类net.sf.hibernate.expression.Expression定义了获得一些内置的Criterion类型。
表达式(Expressions)可以按照逻辑分组.
有很多预制的条件类型(Expression的子类)。有一个特别有用,可以让你直接嵌入SQL。
其中的{alias}是一个占位符,它将会被所查询实体的行别名所替代。(原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)
3、对结果排序
可以使用net.sf.hibernate.expression.Order对结果集排序.
4、关联(Associations)
你可以在关联之间使用createCriteria(),很容易地在存在关系的实体之间指定约束。
下面的替代形式在特定情况下有用。
(createAlias())并不会创建一个Criteria的新实例。)
请注意,前面两个查询中Cat实例所持有的kittens集合类并没有通过criteria预先过滤!如果你希望只返回满足条件的kittens,你必须使用returnMaps()。
5、动态关联对象获取(Dynamic association fetching)
可以在运行时通过setFetchMode()来改变关联对象自动获取的策略。
6、根据示例查询(Example queries)
net.sf.hibernate.expression.Example类允许你从指定的实例创造查询条件。
You can adjust how the Example is applied. 你可以调整示例(Example)如何应用。
<script type="text/JavaScript"> </script><script src="http://a.alimama.cn/inf.js" type="text/javascript"> </script>
你甚至可以用示例对关联对象建立criteria。
版本属性,表示符属性和关联都会被忽略。默认情况下,null值的属性也被排除在外。
这个查询会通过外连接(outer join)同时获得 mate和kittens。
注意,第二个createCriteria()返回一个Criteria的新实例,指向kittens集合类的元素。