`
zwt2001267
  • 浏览: 444766 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Hibernate的检索方式(一)

 
阅读更多

转自:http://aumy2008.blogbus.com/logs/13835265.html

 

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

l         导航对象图检索方式。(根据已经加载的对象,导航到其他对象。)

l         OID检索方式。(按照对象的OID来检索对象。)

l         HQL检索方式。(使用面向对象的HQL查询语言。)

l         QBC检索方式。(使用QBC(Qurey By Criteria) API来检索对象。)

l         本地SQL检索方式。(使用本地数据库的SQL查询语句。)

 

一、Hibernate的检索方式简介

1HQL检索方式

HQLHibernate Query Language)是面向对象的查询语言,它和SQL查询语言有些相识。在Hibernate提供的各种检索方式中,HQL是使用最广的一种检索方式。它具有以下功能:

l         在查询语句中设定各种查询条件。

l         支持投影查询,即仅检索出对象的部分属性。

l         支持分页查询。

l         支持分组查询,允许使用havinggroup by关键字。

l         提供内置聚集函数,如sum()min()mac()

l         能够调用用户定义的SQL函数。

l         支持子查询,即嵌入式查询。

l         支持动态绑定参数。

Session类的find方法及Qurey接口都支持HQL检索方式。区别在于,前者只是执行一些简单HQL查询语句的便捷方法,它不具有动态绑定参数的功能,而且在将来新的Hibernate版本中,有可能淘汰find方法;而Qurey接口才是真正的HQL查询接口,它提供了以上列出的各种查询功能。

       注:Qurey接口支持方法链编程风格,它的set方法都返回自身实例,而不是返回void类型。方法链编程风格能使程序代码更加简洁。

示例代码:

    Query query = session           .createQuery("from Customer as c where "           +"c.name=:customerName and c.age=:customerAge");    // 动态绑定参数    query.setString("customerName", "Test");    query.setInteger("customerAge", 21);    // 执行检索    List result = query.list();     // 方法链编程风格    List result1 = session.createQuery(           "from Customer as c where c.name=:customerName"                  + " and c.age=:customerAge").setString(           "customerName", "Test").setInteger("customerAge", 21)

           .list();

 

2QBCQurey By Criteria)检索方式

       采用HQL检索方式时,在应用程序中需要定义基于字符串形式的HQL查询语句。QBC API提供了检索对象的另一种方式,它主要由Criteria接口、Criterion接口和Expression类组成,它支持在运行时动态生成查询语句。

示例代码:

    Criteria criteria = session.createCriteria(Customer.class);    Criterion criterion1 = Expression.like("namr", "T%");    Criterion criterion2 = Expression.eq("age", new Integer(21));    criteria = criteria.add(criterion1);    criteria = criteria.add(criterion2);    // 执行检索    List result = criteria.list();     // 方法链编程风格    List result1 = session.createCriteria(Customer.class).add(           Expression.like("namr", "T%")).add(

           Expression.eq("age", new Integer(21))).list();

 

       Hibernate还提供了QBE(Qurey By Example)检索方式,它是QBC的子功能。QBE允许先创建一个随想模板,然后检索出和这个样板相同的对象。

示例代码:

    Customer exampleCustomer=new Customer();    exampleCustomer.setAge(21);     List result1 = session.createCriteria(Customer.class).add(

           Example.create(exampleCustomer)).list();

 

       QBE的功能不是特别强大,仅在某些场合下有用。一个典型的使用场合就是在查询窗口中让用户输入一系列的查询条件,然后返回匹配的对象。QBE只支持“”和“”比较运算符,无法不大区间值,及其或的匹配。在这种情况下,还是采用HQL检索方式或QBC检索方式。

 

3SQL检索方式

       采用HQLQBC检索方式时,Hibernate生成标准的SQL查询语句,使用于所有的数据库平台,因此这两种检索方式都是跨平台的

       有的应用程序可能需要根据底层数据库的SQL方言,来生成一些特殊的查询语句。在这种情况下,可以利用Hibernate提供的SQL检索方式。

示例代码:

    Query query = session.createSQLQuery("select {c.*} from CUSTOMER as c where c.NAME like :customerName and c.AGE=:customerAge");    // 动态绑定参数    query.setString("customerName", "Test");    query.setInteger("customerAge", 21);    // 执行检索

    List result = query.list();

 

4、使用别名

       通过HQL检索一个类时,如果查询语句的其他地方需要引用它,应该为这个类指定一个别名,as关键字用于设定别名,也可以将as关键字省略。

       QBC检索不需要由应用程序显式指定类的别名,Hibernate会自动把查询语句中的跟结点实体赋予别名“this”。

 

5、多态查询

       HQLQBC都支持多态查询,多态查询是指查询出当前类及所有子类的实例。多态查询对接口也使用。Hibernate不仅对from子句显式指定的类进行多态查询,而且对其他关联的类也会进行多态查询。

 

6、对查询结果排序

       HQLQBC都支持对查询结果进行排序。

query = session.createQuery("from Customer as c order by c.name");

    //排序    criteria.addOrder(Order.asc("name"));

    criteria.addOrder(Order.desc("age"));

 

7、分页查询

       QueryCriteria接口都提供了用于分页显式查询结果的方法。

l         setFirstResult(int firstResult):设置从那个对象开始检索,参数表示这个对象在查询结果中的索引位置,索引位置的起始值为0。默认从0检索。

l         setMaxResult(int maxResults):设置一次最多检索出的对象数目。默认检索所有。

示例代码:

    criteria = criteria.add(criterion1);    criteria = criteria.add(criterion2);    criteria.setFirstResult(0);    criteria.setMaxResults(10);            // 执行检索

    List result = criteria.list();

     query.setString("customerName", "Test");    query.setInteger("customerAge", 21);    query.setFirstResult(0);    query.setMaxResults(10);            // 执行检索

    List result = query.list();

 

8、检索单个对象

       QueryCriteria接口都提供了以下用于查询语句并返回查询结果的方法。

l         list()方法:返回一个List类型的查询结果。

l         uniqueResult()方法:返回单个对象。

 

注:Query接口还提供了一个iterate()方法,它和list()方法一样,能返回所有满足条件的持久化对象,但是两者使用不同的SQL查询语句。

示例代码:

    // 单个检索    Customer customer = (Customer) session.createQuery(           "from Customer as c order by c.name").setMaxResults(1)

           .uniqueResult();

     // 单个检索    Customer customer = (Customer) session.createCriteria(

           Customer.class).setMaxResults(1).uniqueResult();

       如果明明知道一个对象,可以不调用setMaxResults(1)方法。

 

9、在HQL查询语句中绑定参数

       A、按参数名字绑定。咋HQL中定义命名参数以“:”开头。

       B、按照参数位置绑定。在HQL查询语句中用“?”来定义参数的位置。

示例代码:

    Query query = session.createQuery("from Customer as c where "           + "c.name=? and c.age=?");    // 动态绑定参数    query.setString(0, "Test");

    query.setInteger(1, 21);

 

       除了以上用于绑定映射类型的参数的方法,Hibernate还提供了以下三个特殊的参数绑定方法。

1setEntity()方法:把参数与一个持久化类的实例绑定。(用id关联)

2setParameter()方法:绑定任意类型的参数。

3setProperties()方法:用于把命名参数与一个对象的属性值绑定。

 

10、在映射文件中定义命名查询语句(略)

 

分享到:
评论

相关推荐

    day36-hibernate检索和优化 02-Hibernate检索方式:简单查询及别名查询

    本教程将深入探讨"day36-hibernate检索和优化 02-Hibernate检索方式:简单查询及别名查询"的主题,通过源码分析和实际工具的应用,来提升数据库查询的效率。 首先,我们了解Hibernate的检索方式。在Hibernate中,...

    day36 04-Hibernate检索方式:多表连接查询

    标题中的“day36 04-Hibernate检索方式:多表连接查询”表明这是一个关于Hibernate框架的教程,重点讲解如何在Hibernate中进行多表连接查询。在这个主题中,我们将深入探讨Hibernate的ORM(对象关系映射)机制以及...

    HIBERNATE检索策略

    标题:“HIBERNATE检索策略” 描述:本文深入解析了HIBERNATE的检索策略,为读者提供了一条清晰的学习路径,重点分析了HIBERNATE中的抓取策略及其应用场景,帮助开发者更有效地管理和优化数据加载过程。 在...

    Hibernate的检索方式

    ### Hibernate的五种检索方式详解 #### 一、导航对象图检索方式 导航对象图检索是一种常见的对象关联查询方式。这种方式通常用于加载已经存在于内存中的对象,并通过这些对象访问与其关联的对象。例如,在一个订单...

    Hibernate检索方式

    ### Hibernate检索方式详解 #### 一、概述 Hibernate是一个强大的对象关系映射(ORM)框架,它可以将Java对象与数据库表进行映射,使得开发者能够更方便地进行数据的持久化操作。在Hibernate中,提供了多种检索...

    hibernate5--4.检索方式及策略

    一、Hibernate检索方式 1. **HQL(Hibernate Query Language)**: HQL是Hibernate提供的面向对象的查询语言,类似于SQL,但它是基于类和对象的。你可以通过HQL来查询、更新和删除对象,而无需关心底层的SQL语法。...

    java-Hibernate 检索

    Hibernate 是一个流行的 Java 持久层框架,它提供了多种检索数据的方式,包括导航对象图检索、OID 检索、HQL 检索、QBC 检索和本地 SQL 检索等。下面将详细介绍每种检索方式。 一、导航对象图检索 导航对象图检索...

    Hibernate数据检索(HQL)笔记

    ### Hibernate数据检索(HQL)知识点详解 #### 一、简介 Hibernate 是一款开源的对象关系映射(ORM)框架,它允许开发人员将 Java 对象映射到数据库表中的记录,从而极大地简化了数据访问层的开发工作。本文档基于...

    Hibernate数据检索(HQL)笔记

    在 Hibernate 中,数据检索可以使用 HQL 语句或 Criteria API 两种方式。HQL 语句是一种类似 SQL 的查询语言,用于定义查询条件和检索数据,而 Criteria API 则是一种基于对象的查询接口,用于构建查询条件和检索...

    基于Spring的Hibernate Search全文检索功能示例

    3. **Hibernate Search**:作为Hibernate的一个扩展,Hibernate Search提供了基于Lucene的全文检索功能,使得在数据库中的数据可以被快速、精确地搜索。 **二、集成Hibernate Search** 1. **配置依赖**:首先,你...

    浪磬J2EE第一期 Hibernate专题 第六讲 检索方式

    一、Hibernate检索方式概述 Hibernate提供了多种检索数据的方法,以适应不同的需求场景。这些方法包括:HQL(Hibernate Query Language)、QBC(Query By Criteria)、Criteria API以及直接使用Session的get()和load...

    Hibernate的检索策略

    在Java持久化框架Hibernate中,检索策略是一种重要的机制,它主要用于控制对象何时以及如何加载到应用程序内存中。合理的检索策略不仅可以提高应用性能,还能简化代码逻辑,使得开发过程更加高效。Hibernate支持两种...

    hibernate基础 注解开发 检索

    Hibernate提供了多种方式来查询数据,包括HQL、QBC和本地SQL。 - **HQL (Hibernate Query Language)**:一种面向对象的查询语言,类似于SQL但更加面向对象。 - **QBC (Query By Criteria)**:基于标准的API提供了一...

    Hibernate 对象的状态检索

    本人在厦门邦初培训时候 使用的快速入门精简文档 Session缓存的作用 Session清理缓存的时间点 对象的临时状态、持久状态和游离状态 用session的update()方法使游离对象转变为持久化对象。...本地SQL检索方式

    hibernate框架学习,由浅入深

    Hibernate 提供了多种 O/R 映射方式,包括一对一、一对多、多对多等。 8. Hibernate 数据关联 Hibernate 数据关联是指在 JavaBean 对象之间的关联关系。 Hibernate 提供了多种数据关联方式,包括一对一、一对多、...

    hibernate的延迟检索在轻量级J2EE框架中的应用

    通过这种方式,只有当确实需要访问集合中的数据时,Hibernate才会执行数据库查询,从而节省了资源。 #### 3. 延迟加载在轻量级J2EE框架中的应用 在轻量级J2EE框架中,如Spring+Hibernate,延迟加载机制的应用非常...

    hibernate的检索

    【Hibernate检索策略】 Hibernate提供三种主要的检索策略:立即检索、延迟检索和迫切左外连接检索。 1. **立即检索**:这种策略将立即加载关联的对象,无论对象是持久化状态还是游离状态。优点是应用程序可以方便...

    hibernate3 hibernate3

    Session提供了一种透明的方式来保存和检索对象,同时也负责事务管理。 5. Querying:Hibernate提供了HQL(Hibernate Query Language)和Criteria API,它们是面向对象的查询语言,可以方便地查询数据库。 二、...

Global site tag (gtag.js) - Google Analytics