`

Hibernate:HQL/QBC查询语言比较的用法 1

阅读更多
Hib的检索方式

1、导航对象图检索方式。通过已经加载的对象,调用.iterator()方法可以得到order对象如果是首次执行此方法,Hib会从数据库加载关联的order对象,否则就从缓存中得到。

2、OID检索方式。通过session的get,load方法知道了OID的情况下可以使用

3、HQL检索方式。使用面向对象的HQL查询语句session的find方法利用HQL来查询

4、QBC检索方式。利用QBCAPI来检索它是封装了基于字符串的查询语句

5、本地的SQL检索方式。使用本地数据库的SQL查询语句Hib会负责把检索到的JDBC结果集映射为持久化对象图。

五种检索方式的使用场合和特点:

HQL : 是面向对象的查询语言,同SQL有些相似是Hib中最常用的方式。

查询设定各种查询条件。

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

支持分页查询,允许使用having和group by

提供内制的聚集函数,sum(),min(),max()

能调用用户的自定义SQL

支持子查询,嵌入式查询

支持动态绑定参数

建议使用Query接口替换session的find方法。


Query Q = session.createQuery

("from customer as c where c.name

= :customerName" +

"and c.age = :customerAge");

   query.setString

   ("customerName" , "tom");

   query.setInteger

   ("customerAge" , "21");

   list result = query.list();




QBC : QBCAPI提供了另一种方式,主要是Criteria接口、Criterion接口和Expression类


Criteria criteria =

session.createCriteria(customer.class);

   Criterion criterion1 =

   Expression.like("name","t%");

   Criterion criterion2 =

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

   Critera = criteria.add(criterion1) ;

   Critera = criteria.add(criterion2) ;

   list result = criteria.list();




或是:


list result = session.createCriteria(Customer.class).

add(Expression.eq("this.name","tom")).list();




SQL :

采用HQL和QBC检索时,Hib生成SQL语句适用所有数据库。


Query query  =

session.createSQLQuery("select

{

c.*

}

from customers c where c.name

like : customername " + "and c.age =

:customerage","c",customer.calss);

   query.setString("customername","tom");

   query.setInteger("customerage","21");

   list result = query.list();

/////////////多态查询

   HQL :session.createQuery("from employee");

   QBC :session.createCriteria(employee.class);

   HQL : session.createQuery("from hourlyEmployee");

   QBC : session.createCriteria(hourlyEmployee.class);




下面的HQL查询语句将检索出所有的持久化对象:


from java.lang.Object ;

from java.io.serializable ;

////////////查询的排序




1、查询结果按照客户姓名升序排列:


HQL :

Query query = session.createQuery

("from customer c order by c.name");

QBC :

Criteria criteria =

session.createCriteria(customer.class);

criteria.addOrder(order.asc("name"));

HQL :

Query query = session.createQuery

("from customer c order

by c.name asc , c.age desc");

QBC :

Criteria criteria =

session.createCriteria

(customer.class);

criteria.addOrder

(order.asc ("name"));

criteria.addOrder

(order.desc("age"));

import net.sf.hibernate.pression.Order

import mypack.Order

...........

Criteria criteria =

session.createCritria

(mypack.Order.class);

criteria.addOrder

(net.sf.hibernate.Order.asc("name"));

///////////HQL语句的参数绑定Query接口

提供了绑定各种Hib映射类型的方法。

setBinary()

setString()

setBoolean()

setByte()

setCalendar()

setCharacter()

setDate()

setDouble()

setText()

setTime()

setTimestamp()

setEntity()

//把参数与一个持久化类的事例绑定

lsit result = session.createQuery

("from order o where o.customer =           

:customer").setEntity

("customer" , customer).list ;

setParameter()

//绑定任意类型的参数

setProperties()

//把命名参数与一个对象的属性值绑定

Query query = session.createQuery

("from customer c where c.name =:    

name " + "and c.age =:age" );

Query.setProperties(customer);

来源:javaresearch
分享到:
评论

相关推荐

    Hibernate-HQL-QBC-QBE

    2. HQL(Hibernate Query Language):HQL是Hibernate提供的面向对象的查询语言,类似于SQL,但它是针对对象而不是表格进行操作的。HQL允许开发者以类和对象的方式编写查询,支持复杂的查询结构,如连接、子查询、...

    Hibernate实例开发 HQL 与 QBC 查询

    首先,HQL是Hibernate专门设计的一种面向对象的查询语言,它的语法类似于SQL,但更注重对象而非表。例如,如果我们有一个`User`实体,我们可以使用HQL来获取所有用户: ```java Session session = sessionFactory....

    HQL与QBC的查询条件.doc

    HQL是一种面向对象的查询语言,类似于SQL,但它是针对对象和类的,而不是针对表和列。HQL允许开发者以类和对象的方式书写查询,从而避免了直接处理底层数据库的复杂性。以下是一些常见的HQL运算符: 1. **比较运算*...

    精通hibernate HQL语言

    HQL,全称Hibernate Query Language,是Hibernate框架提供的一种面向对象的查询语言,它的语法结构与SQL相似,但主要针对对象和实体进行操作,而不是直接操作数据库表。HQL是Hibernate官方推荐的检索数据的主要方式...

    Java_Hibernate QBC条件查询对比

    相对而言,HQL是一种面向对象的查询语言,类似于SQL,但更加面向对象。开发者可以直接在HQL语句中指定类名、属性名,进行复杂的查询操作,包括但不限于分页、排序、联接等。HQL的优势在于其强大的功能,能够处理复杂...

    QBC查询的别名方的

    - **HQL与HBM的关系**:HQL是一种面向对象的查询语言,用于查询和操作Hibernate管理的对象。它依赖于HBM映射文件定义的对象模型,因此,正确配置HBM文件对于HQL的正常使用至关重要。 #### 2. Projection在查询中的...

    hibernate 数据库操作方法

    HQL是Hibernate特有的面向对象的查询语言,其语法类似于SQL,但操作的是对象和集合。它可以更自然地映射到Java对象。例如,查找所有年龄大于30岁的用户: ```java String hql = "FROM User WHERE age > :age"; ...

    Hibernate学习笔记(3)

    ### Hibernate中的HQL与QBC查询详解 #### 一、引言 Hibernate作为一个强大的对象关系映射(ORM)框架,极大地简化了Java开发者与数据库交互的过程。本文将深入探讨Hibernate中两种常用的查询语言——HQL...

    Hibernate的查询方式

    HQL是Hibernate特有的查询语言,它采用面向对象的语法结构,使开发者能够在不脱离对象模型的情况下进行数据库操作。与传统的SQL相比,HQL更侧重于对象的属性和关联,而非数据库的表和字段,这使得代码更易于理解和...

    hibernate查询详解

    Hibernate Query Language(HQL)是一种面向对象的查询语言,类似于SQL但更专注于对象而不是表格。HQL查询分为HQL查询和HQL命名查询。 A. HQL查询:通过编写HQL语句来执行查询,例如: ```java String hql=...

    4.Hibernate-04查询以及优化策略1

    HQL(Hibernate Query Language,Hibernate 查询语言)是 Hibernate 提供的一种查询语言,它可以用于查询数据库中的数据。HQL 查询可以分为两种:一种是基于对象的查询,另一种是基于 SQL 的查询。 1.1 基于对象的 ...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part2

     2.2.2 ORM中间件的基本使用方法  2.2.3 常用的ORM中间件  2.3 实体域对象的其他持久化模式  2.3.1 主动域对象模式  2.3.2 JDO模式  2.3.3 CMP模式  2.4 Hibernate API简介  2.4.1 Hibernate的核心接口  ...

    Hibernate查询语言.doc

    本文主要探讨Hibernate中的查询语言,包括面向对象的查询语言HQL,QueryBy Criteria (QBC),Query By Example (QBE),以及原生SQL的使用。 1. **大小写敏感性** HQL查询语句对Java类和属性名称的大小写敏感,而...

    Hibernate基本实现

    1. **HQL(Hibernate Query Language)**:类似SQL的语言,用于在对象层面上进行查询。 ```java Query<User> query = session.createQuery("from User", User.class); List<User> users = query.list(); ``` 2...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part1.rar

     2.2.2 ORM中间件的基本使用方法  2.2.3 常用的ORM中间件  2.3 实体域对象的其他持久化模式  2.3.1 主动域对象模式  2.3.2 JDO模式  2.3.3 CMP模式  2.4 Hibernate API简介  2.4.1 Hibernate的核心接口  ...

    Hibernate教程21_HIbernate查询

    1. **s2sh_relation20_HQL.zip**: 包含了关于HQL查询的示例代码和说明,可以帮助你掌握基本的HQL语法和使用方法。 2. **s2sh_relation21_QBC.zip**: 提供了Query by Criteria的实践案例,通过解压和运行这些代码,你...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part4

     2.2.2 ORM中间件的基本使用方法  2.2.3 常用的ORM中间件  2.3 实体域对象的其他持久化模式  2.3.1 主动域对象模式  2.3.2 JDO模式  2.3.3 CMP模式  2.4 Hibernate API简介  2.4.1 Hibernate的核心接口  ...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part3

     2.2.2 ORM中间件的基本使用方法  2.2.3 常用的ORM中间件  2.3 实体域对象的其他持久化模式  2.3.1 主动域对象模式  2.3.2 JDO模式  2.3.3 CMP模式  2.4 Hibernate API简介  2.4.1 Hibernate的核心接口  ...

    hibernate中文帮助文档

    6. **HQL与QBC**: Hibernate查询语言(HQL)是面向对象的查询语言,类似SQL但更接近Java。另外,Query By Criteria(QBC)提供了一种基于对象的查询方式,可以动态构建查询条件。 7. **级联操作与缓存**: Hibernate...

    myFirstHibernate

    5. Criteria/Query/HQL:查询语言,提供了面向对象的查询方式。 三、"myFirstHibernate"项目配置 在"myFirstHibernate"项目中,首先我们需要创建一个hibernate.cfg.xml配置文件,其中包含数据库连接信息、方言设置...

Global site tag (gtag.js) - Google Analytics