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);
过滤查询结果中的重复元素
使用Set集合来去除重复元素;或是使用distinct元素
Iterator iterator = session.createQuery("select distinct c.name from customer ").list().iterator();
while(iterator.hasnext()){
String name = (String) it.next() ;
}
///////////使用聚集函数
count(); 记录的条数
min(); 求最小值
max(); 求最大值
avg(); 求平均值
sum(); 求和
1'查询customer中的所有记录条数
integer i = (Integer) session.createQuery("select count(*) from customer").uniqueResult();
2'查询customer中的所有客户的平均年龄
integer i = (Integer) session.createQuery("select avg(c.age) from customer c ").uniqueResult();
3'查询customer中的客户年龄的最大值、最小值
object [] i = (Integer) session.createQuery("select max(c.age),min(c.age) from customer c ").uniqueResult();
Integer Maxage = (Integer) i [0];
Integer Minage = (Integer) i [1];
4'统计customer中的客户的名称数目,忽略重复的姓名
Integer cout = (Integer) session.createQuery("select count(distinct c.name) from customer c").uniqueResult();
////////////使用分组查询
1'按姓名分组,统计customer中的相同姓名的记录数目
Iterator iterator = (Integer) session.createQuery("select c.name ,count(c) from customer c group by c.name").list.iterator();
while(iterator.hasnext()){
object[] p = (objcet[])iterator.next();
String name = p[0];
Integer cout = p[1];
}
2'按客户分组,统计每个客户的订单数量
Iterator iterator = session.crateQuery("select c.id ,c.name , count(o) from customer c join c.order o group by c.id ").list().iterator;
while(iterator.hasnext()){
object[] p = (objcet[])iterator.next();
Integer id = p[0]
String name = p[1];
Integer cout = p[2];
}
3'统计每个客户的订单总价
Iterator iterator = session.crateQuery("select c.id ,c.name,sum(o.price) from customer c join c.order o group by c.id").list.iterator();
while(iterator.hasnext()){
object[] p = (objcet[])iterator.next();
Integer id = p[0]
String name = p[1];
Double cout = p[2];
}
//////////报表的优化
使用HQL时如果只查询对象的一部分属性不会返回持久化对象
from customer c join c.order o group by c.age;//返回持久化对象,占用缓存。
select c.id , c.name , c.age ,o.id ,o.price from customer c join c.order o group by c.age //返回关系性数据,不占用session的缓存,可以为JVM回收
/////////HQL子查询的集合函数属性
size() 返回集合中元素的数目
minIndex() 建立索引的集合获得最小的索引
maxIndex() 建立索引的集合获得最大的索引
minElement() 对于包含基本元素的集合获得集合最小的元素
maxElement() 对于包含基本元素的集合获得集合最大的元素
element() 获得集合中的所有元素
///////////Hibernate的缓存管理
管理一级缓存,不建议使用下列方法来管理一级缓存
evict(Object o)从缓存中清除参数指定的持久化对象
clear()清空缓存中所有的持久化对象
///////////批量更新和批量删除
批量更新customer表中的年龄大于零的所有记录的AGE字段:
tx = session.beginTransaction();
Iterator customer = session.find("from customer c where c.age > 0").iterator();
while(iterator.hasnext()){
customer customer = (customer) customer.next();
customer.setAge(customer.getAge()+1);
}
tx.commit();
session.close();//上述代码对数据库操作效果不好可以使用下列的JDBCAPI直连
tx = session.beginTranscation();
Connection conn = session.connection();
Preparedstatement ps = conn.preparedstatment("update customer set age = age + 1 where age > 0 ");
ps.executeupdate();
tx.commit();
来源:javaresearch
分享到:
相关推荐
2. HQL(Hibernate Query Language):HQL是Hibernate提供的面向对象的查询语言,类似于SQL,但它是针对对象而不是表格进行操作的。HQL允许开发者以类和对象的方式编写查询,支持复杂的查询结构,如连接、子查询、...
首先,HQL是Hibernate专门设计的一种面向对象的查询语言,它的语法类似于SQL,但更注重对象而非表。例如,如果我们有一个`User`实体,我们可以使用HQL来获取所有用户: ```java Session session = sessionFactory....
HQL是一种面向对象的查询语言,类似于SQL,但它是针对对象和类的,而不是针对表和列。HQL允许开发者以类和对象的方式书写查询,从而避免了直接处理底层数据库的复杂性。以下是一些常见的HQL运算符: 1. **比较运算*...
HQL,全称Hibernate Query Language,是Hibernate框架提供的一种面向对象的查询语言,它的语法结构与SQL相似,但主要针对对象和实体进行操作,而不是直接操作数据库表。HQL是Hibernate官方推荐的检索数据的主要方式...
相对而言,HQL是一种面向对象的查询语言,类似于SQL,但更加面向对象。开发者可以直接在HQL语句中指定类名、属性名,进行复杂的查询操作,包括但不限于分页、排序、联接等。HQL的优势在于其强大的功能,能够处理复杂...
- **HQL与HBM的关系**:HQL是一种面向对象的查询语言,用于查询和操作Hibernate管理的对象。它依赖于HBM映射文件定义的对象模型,因此,正确配置HBM文件对于HQL的正常使用至关重要。 #### 2. Projection在查询中的...
HQL是Hibernate特有的面向对象的查询语言,其语法类似于SQL,但操作的是对象和集合。它可以更自然地映射到Java对象。例如,查找所有年龄大于30岁的用户: ```java String hql = "FROM User WHERE age > :age"; ...
### Hibernate中的HQL与QBC查询详解 #### 一、引言 Hibernate作为一个强大的对象关系映射(ORM)框架,极大地简化了Java开发者与数据库交互的过程。本文将深入探讨Hibernate中两种常用的查询语言——HQL...
HQL是Hibernate特有的查询语言,它采用面向对象的语法结构,使开发者能够在不脱离对象模型的情况下进行数据库操作。与传统的SQL相比,HQL更侧重于对象的属性和关联,而非数据库的表和字段,这使得代码更易于理解和...
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 Query Language(HQL)是一种面向对象的查询语言,类似于SQL但更专注于对象而不是表格。HQL查询分为HQL查询和HQL命名查询。 A. HQL查询:通过编写HQL语句来执行查询,例如: ```java String hql=...
HQL(Hibernate Query Language,Hibernate 查询语言)是 Hibernate 提供的一种查询语言,它可以用于查询数据库中的数据。HQL 查询可以分为两种:一种是基于对象的查询,另一种是基于 SQL 的查询。 1.1 基于对象的 ...
本文主要探讨Hibernate中的查询语言,包括面向对象的查询语言HQL,QueryBy Criteria (QBC),Query By Example (QBE),以及原生SQL的使用。 1. **大小写敏感性** HQL查询语句对Java类和属性名称的大小写敏感,而...
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的核心接口 ...
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的核心接口 ...
1. **HQL(Hibernate Query Language)**:类似SQL的语言,用于在对象层面上进行查询。 ```java Query<User> query = session.createQuery("from User", User.class); List<User> users = query.list(); ``` 2...
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的核心接口 ...
1. **s2sh_relation20_HQL.zip**: 包含了关于HQL查询的示例代码和说明,可以帮助你掌握基本的HQL语法和使用方法。 2. **s2sh_relation21_QBC.zip**: 提供了Query by Criteria的实践案例,通过解压和运行这些代码,你...
6. **HQL与QBC**: Hibernate查询语言(HQL)是面向对象的查询语言,类似SQL但更接近Java。另外,Query By Criteria(QBC)提供了一种基于对象的查询方式,可以动态构建查询条件。 7. **级联操作与缓存**: Hibernate...
5. Criteria/Query/HQL:查询语言,提供了面向对象的查询方式。 三、"myFirstHibernate"项目配置 在"myFirstHibernate"项目中,首先我们需要创建一个hibernate.cfg.xml配置文件,其中包含数据库连接信息、方言设置...