HQL(Hibernate Query Language)
是面向对象的查询语言, 它和 SQL 查询语言有些相似. 在 Hibernate 提供的各种检索方式中, HQL 是使用最广的一种检索方式. 它有如下功能:
l 在查询语句中设定各种查询条件
l 支持投影查询, 即仅检索出对象的部分属性
l 支持分页查询
l 支持连接查询
l 支持分组查询, 允许使用 HAVING 和 GROUP BY 关键字
l 提供内置聚集函数, 如 sum(), min() 和 max()
l 能够调用 用户定义的 SQL 函数或标准的 SQL 函数
l 支持子查询
l 支持动态绑定参数
OID 检索方式
按照对象的 OID 来检索对象
1. 提供一个无参的构造器。使Hibernate可以使用Constructor.newInstance() 来实例化持久化类。
2. 提供一个标识属性(identifierproperty)。通常映射为数据库表的主键字段。如果没有该属性,一些功能将不起作用,如:Session.saveOrUpdate()。
3. 为类的持久化类的字段声明访问方法(get/set)。Hibernate对JavaBeans风格的属性实行持久化。
4. 使用非final类。在运行时生成代理是Hibernate的一个重要的功能。如果持久化类没有实现任何接口,Hibnernate使用 CGLIB 生成代理。如果使用的是 final 类,则无法生成CGLIB代理。
5. 重写eqauls()和hashCode()方法。如果需要把持久化类的实例放到Set中(当需要进行关联映射时),则应该重写这两个方法。
QBC 检索方式
使用 QBC(Query ByCriteria) API 来检索对象. 这种 API 封装了基于字符串形式的查询语句, 提供了更加面向对象的查询接口.它提供了更加面向对象的操作方式。
OGNL检索方式
就是在HQL中使用.来获取对象的属性
本地SQL方式
与本地数据库绑定,但是效率比较高。