`
hendryxu
  • 浏览: 123488 次
  • 来自: ...
最近访客 更多访客>>
社区版块
存档分类
最新评论

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);
分享到:
评论

相关推荐

    HQL与QBC的查询条件.doc

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

    Hibernate实例开发 HQL 与 QBC 查询

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

    Hibernate-HQL-QBC-QBE

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

    QBC查询的别名方的

    本文详细解析了QBC查询中的几个关键概念及其应用场景,包括HBM映射文件与HQL的关系、Projection的作用、Criterion和Order条件的使用等。此外,还提供了一个简单的JavaScript页面刷新示例。通过这些内容的学习,可以...

    精通hibernate HQL语言

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

    NHibernate HQL 条件查询

    而HQL则是NHibernate提供的一种查询语言,它允许开发人员使用类似于SQL的语法来查询数据库,同时保持了面向对象的特性。 ### NHibernate HQL条件查询详解 #### QBC(Query By Criteria)与HQL对比 在NHibernate中...

    Java_Hibernate QBC条件查询对比

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

    HQL经典语句

    HQL(Hibernate Query Language)是Hibernate框架提供的一种查询语言,它结合了SQL的强大功能和面向对象编程的特点,使得开发者能够以更自然、更直观的方式进行数据库查询操作。HQL支持标准的SQL查询语法,并在此...

    Hql详解[文].pdf

    Hibernate Query Language(Hql)是Hibernate框架中用于操作对象-关系映射(ORM)的一种语言,它模仿了EJBQL的设计,旨在提供一种跨数据库的查询方式。Hql与SQL有诸多相似之处,但其核心是面向对象而非数据库表格,...

    Hibernate学习笔记(3)

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

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

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

    java-Hibernate 检索

    HQL 是一种面向对象的查询语言,可以使用 HQL 语句来检索对象。 步骤: 1. 获得 Session 2. 编写 HQL 3. 通过 session.createQuery(hql) 创建 Query 对象 4. 为 Query 对象设置条件参数 5. 执行查询 list() ---- ...

    Hibernate查询语言.doc

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

    Hibernate的查询方式

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

    Hibernate Query Language基础使用详解

    Hibernate Query Language(HQL)是Hibernate官方推荐的查询语言,它是面向对象的,与SQL类似,但更加符合Java编程的思维。HQL使得开发者能够更方便地处理对象关系映射,而无需直接编写SQL语句。在使用HQL时,我们...

    hibernate查询详解

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

    继承关系映射和HibernateQBC查询

    ### 继承关系映射和Hibernate QBC查询 #### 继承关系映射 继承作为面向对象编程的一个核心概念,在Java等面向对象语言中极为常见。然而,在数据库中表示继承关系并不直观,因为数据库通常使用表格来存储数据,而...

    hibernate 数据库操作方法

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

    hibernate常用语句

    1. HQL(Hibernate Query Language)是面向对象的查询语言,它允许开发者以类和属性的名字而不是表和列名进行查询。例如: ```java // 查询username为"name1"的唯一Customer对象 Query query = session.createQuery...

    hibernate查询

    HQL 查询是基于 SQL 的一种面向对象的查询语言,它可以实现复杂的查询操作,同时保持代码的简洁性和可读性。 **特点:** - **面向对象**:使用 HQL 可以以面向对象的方式编写 SQL 语句。 - **语法简洁**:与原生 ...

Global site tag (gtag.js) - Google Analytics