Hibernate提供了以下几种检索对象的方式:

A、导航对象图检索方式。
B、OID检索方式。Session.get() load();
C、HQL检索方式。Query.
D、QBC检索方式。Query By Criteria.
E、本地SQL检索方式。

一、HQL检索方式:Hibernate Query Language
  HQL是面向对象的查询语言。它包含以下功能:

1、在查询语句中设定各种查询条件。
2、支持投影查询,即仅检索出对象的部分属性。
3、支持分页查询。
4、支持连接查询。
5、支持分组查询,允许使用having和group by关键字。
6、提供内置聚集函数,如sum()、min()和max()。
7、能够调用用户自定义的SQL函数或者标志SQL函数。
8、支持子查询,即嵌入式查询。
9、支持动态绑定参数。

二、QBC检索方式
  QBC API提供了检索对象的另一种方式,它以Criteria接口、Criterion接口、Restrictions接口组成,支持在运行时动态生成查询语句。
实例代码:

//创建一个Criteria对象
Criteria criteria = session.createCriteria(Customer.class);
//设定查询条件,然后把查询条件加入到Criteria中。
Criterion criterion1 = Restrictions.like("name","T%");
Criterion criterion2 = Restrictions.eq("age",new Integer(21)); criteria = criteria.add(criterion1);
criteria = criteria.add(criterion2); List result = criteria.list(); //支持链式编程
List result=session.createCriteria(Customer.class)
.add(Restrictions.like("name","T%"))
.add(Restrictions.eq("age",new Integer(21)))
.list();

上述程序执行的SQL语句为:

select ID,NAME,AGE from CUSTOMERS where NAME like 'T%' and AGE = 21;

因此,QBC检索方式的一般步骤为:
  1、调用Session接口的createCriteria方法创建一个Criteria对象。
  2、设定查询条件。
  3、调用Criteria接口的list()方法。

三、本地SQL检索方式
此种方式一般是针对SQL方言生成一些特殊的查询语句。
一个实例代码说明:

Query query = session.createSQLQuery("select * from CUSTOMERS where NAME like :customerName and AGE=:customerAge");
query.setString("customerName","T%");
query.setInteger("customerAge", 21);
list result = query.list();

四、多态查询
HQL和QBC都支持多态查询,多态查询是指查询出当前类及所有的子类的实例。
举例说明:
  HQL中:from java.lang.Object将检索出所有的持久化对象。
  from java.io.Serializable将检索出所有实现该接口的持久化对象。

五、对查询结果排序
  HQL通过order by关键字对查询结果排序。
  QBC通过org.hibernate.criterion.Order类对查询结果排序。
  实例代码

//HQL方式
Query query = session.createQuery("from Customer c order by c.name");
//QBC方式:
Criteria criteria = session.createCriteria(Customer.class);
criteria.addOrder(Order.asc("name"));

六、分页查询
  通过Query或者Criteria接口的setFirstResult(int firstResult);和setMaxResult(int maxResult);实现。

七、检索单个对象(uniqueResult()方法)
  对Query或者Criteria接口都有效。
  setMaxResult(1).uniqueResult();

八、按主键逐个处理查询结果(iterate()方法)
  list()方法执行的SQL语句中包含表中的所有字段,即selec * from tablename...
  iterate()方法执行的SQL语句仅包含ID字段,即select ID from tablename...
  当调用Iterator.next()方法时,先到Session缓存及二级缓存中查看是否存在拥有特定OID的对象,不存在时再去数据库中加载。
  一般情况下应该考虑使用list()方法,以下场合可以考虑使用iterate()方法提高查询性能:
    1、表中包含了大量的字段。
    2、启动了二级缓存,而且二级缓存中可能已经包含待查询的对象。

九、可滚动的结果集
  Query或者Criteria接口的scroll()方法返回一个ScrollableResults对象,它就代表可滚动的结果集。
  不做详解。
十、在HQL查询语句中绑定参数
  1、绑定方式:按名称绑定和按位置绑定。
  2、绑定的API

setString()...
setEntity()...和一个持久化类的实例绑定。
setParameter("name",name,Hibernate.STRING)...第三个参数显式指定Hibernate映射类型。
setProperties()...了解即可

十一、设置查询附属事项
Query或者Criteria接口的方法:

setFlushMode():设置清理缓存的模式。通过FlushMode的三个常量来指定。
setCacheMode():设置Session与第二级缓存的交互模式。通过CacheMode的5个常量来指定。
setTimeout():设置执行查询数据库操作的超时时间。
setFetchSize():为JDBC驱动程序设置批量抓取的数目。
setLockMode():设置所得模式。
setComment():为SQL日志设置注解。

Session.setReadOnly():设置查询结果是否只允许读。

十二、在映射文件中定义命名查询语句
  <query name="findCustomerByName" ...> <sql-query...>
  代码:

Query query = session.getNameedQuery("findCustomerByName"); 

十三、在HQL查询语句中调用函数
  除了预置的函数以外,还可以通过Configuration.addSqlFunction()方法把特定的SQL函数注册到HQL中。

十四、设定查询条件
  HQL查询语句可以通过where子句来设定查询条件。
  QBC则必须创建一个Criterion对象来设定查询条件。通过Restrictions类来创建,参见上面的例子。支持比较运算、范围运算、字符串模式匹配、逻辑运算、集合运算。

攻城狮在路上(壹) Hibernate(十三)--- Hibernate的检索方式(上)的更多相关文章

  1. 攻城狮在路上(壹) Hibernate(十八)--- 管理Hibernate的缓存

    一般Session的缓存被称为Hibernate的第一级缓存,SessionFactory的外置缓存是一个可配置的缓存插件,称为Hibernate的第二级缓存.一.缓存的基本原理: 1.持久化层的缓存 ...

  2. 攻城狮在路上(壹) Hibernate(十六)--- Hibernate声明数据库事务

    一.数据库事务的概念: 数据库的ACID特征:Atomic.Consistency.Isolation.Durability.原子性.一致性.隔离性.持久性.不同的隔离级别引发的不同问题. 事务的AC ...

  3. 攻城狮在路上(壹) Hibernate(十四)--- Hibernate的检索方式(下)

    本节介绍HQL和QBC的高级用法:各种连接查询.投影查询.报表查询.动态查询.集合过滤和子查询等.另外将归纳优化查询程序代码,从而提高查询性能的各种技巧.一.连接查询: HQL与QBC支持的各种连接类 ...

  4. 攻城狮在路上(壹) Hibernate(四)--- 对象标识符(OID)生成机制

    Hibernate使用对象标识符(OID)来建立内存中对象和数据库表中记录的对应关系,对象的OID和数据库的主键对应.为了保证OID的唯一性和不可变性,应该让Hibernate来为OID赋值.Hibe ...

  5. 攻城狮在路上(壹) Hibernate(二)--- 第一个hibernate程序

    1.直接通过JDBC API持久化实体域对象: A.java.sql常用接口和类: DriverManager:驱动程序管理器,负责创建数据库连接. Connection:代表数据库连接. State ...

  6. 攻城狮在路上(壹) Hibernate(十七)--- Hibernate并发处理问题

    一.多个事务并发运行时的并发问题: 总结为第一类丢失更新.脏读.虚读.不可重复读.第二类丢失更新. 1.第一类丢失更新: 撤销一个事务时,把其他事务已提交的更新数据覆盖. 2.脏读: 一个事务读到另一 ...

  7. 攻城狮在路上(壹) Hibernate(十五)--- Hibernate的高级配置

    一.配置数据库连接池: 1.使用默认的数据库连接池: Hibernate提供了默认了数据库连接池,它的实现类为DriverManegerConnectionProvider,如果在Hibernate的 ...

  8. 攻城狮在路上(壹) Hibernate(十二)--- Hibernate的检索策略

    本文依旧以Customer类和Order类进行说明.一.引言: Hibernate检索Customer对象时立即检索与之关联的Order对象,这种检索策略为立即检索策略.立即检索策略存在两大不足: A ...

  9. 攻城狮在路上(壹) Hibernate(十)--- 映射值类型集合

    一.映射Set(集):未排序,无重复. 实例代码: <set name="images" table="IMAGES" lazy="true&q ...

随机推荐

  1. C/C++程序员必须熟练应用的开源项目[转]

    作为一个经验丰富的C/C++程序员, 肯定亲手写过各种功能的代码, 比如封装过数据库访问的类, 封装过网络通信的类,封装过日志操作的类, 封装过文件访问的类, 封装过UI界面库等, 也在实际的项目中应 ...

  2. 什么情况下可以不写PHP的结束标签“?>”

    我们经常看到有些PHP文件中的代码是只有开始标签,而没有结束标签的,那么什么情况下可以不写这个结束标签,而什么情况下必须写?先来看2个例子: 下面的代码正常运行: <?php echo 1234 ...

  3. POJ 1458 1159

    http://poj.org/problem?id=1458 一道容易的DP,求最长公共子序列的 dp[i][j],代表str1中的第i个字母和str2中的第j个字母的最多的公共字母数 #includ ...

  4. jenkins结合ansible用shell实现自动化部署和回滚

    最近用jenkins+gitlab+ansible做持续化集成,自动化部署和版本回滚.然而deploy plugin没能做到增量升级和回滚操作,折腾了很久决定自己写个脚本来简单实现. 环境: cent ...

  5. ios UIWindow 错误使用导致无法接收motionEnded(摇一摇)函数

    今天遇到一个问题,第一次运行程序时,- (void)motionEnded:(UIEventSubtype)motion withEvent:(UIEvent *)event函数无法调用,第二次就好了 ...

  6. nginx服务器设置url的优雅链接

    对于LNMP这样架构的网站来说,一般都是基于php框架开发,php框架一般都会讲究优雅链接,比如Laravel,CodeIgniter,ThinkPHP等都是支持这种链接模式的,在服务器配置上也叫作u ...

  7. 13. javacript高级程序设计-事件

    1. 事件 1.1 事件流 事件流描述的是从页面中接受事件的顺序,IE的事件是冒泡流,而Netscape Communicator的事件流是事件捕捉流. 1.1.1 事件冒泡 <!DOCTYPE ...

  8. HTTP 错误 500.19- Internal Server Error 错误解决方法

    1.点击发布的文件夹,选择属性 2.选择安全,添加一个用户就可以了,设置为完全 --今天公司网页打开出现Server Error in '/' Application.怎么样解决. 解决方法:控制面板 ...

  9. SprignMVC+myBatis整合

    转载自:http://lydia-fly.iteye.com/blog/2153076 学习本节内容请先看"MyBatis的基本应用".地址:http://lydia-fly.it ...

  10. 【leetcode】Sort Colors(middle)☆

    Given an array with n objects colored red, white or blue, sort them so that objects of the same colo ...