http://bbs.itcast.cn/article-211-1.html
员工表 department
CREATE TABLE `employee` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(255) default NULL,
`age` int(11) NOT NULL,
`birthday` date default NULL,
`department_id` int(11) default NULL,
PRIMARY KEY (`id`),
FOREIGN KEY (`department_id`) REFERENCES `department` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2.2.使用JPA注解配置实体类
部门类 Department
员工类 Employee
2.3使用Crteria查询所有部门和所有员工
2.3.1查询所有部门
产生的SQL语句:
查询所有员工
产生的SQL语句:
当session.createCriteria(实体类.class) 就会产生一条select所有列from 表;SQL语句,查询实体类对应数据表的所有记录,然后我们就可以在这个Criteria对象上进行条件查询、分页查询、多表关联查询、投影查询、子查询等一系列操作……
3.Criteria SQL定制详解
3.1对查询添加条件对象Criterion
org.hibernate.criterion.Criterion是Hibernate提供的一个面向对象查询条件接口,一个单独的查询就是Criterion接口的一个实例,用于限制Criteria对象的查询,在Hibernate中Criterion对象的创建通常是通过Restrictions 工厂类完成的。
Restrictions 提供条件查询方法:
例如:
1、查询姓“张”的所有员工信息
产生的SQL语句:
2、查询年龄大于24的所有员工
产生的SQL语句:
3、查询年龄小于28的姓“王”的员工
产生的SQL语句:
对于多个查询条件,Restrictions提供了逻辑组合查询方法。
and(Criterion lhs, Criterion rhs) 用于生成多个条件and关系SQL语句;
or(Criterion lhs, Criterion rhs) 用于生成多个条件or关系SQL语句;
not(Criterion expression) 用于查询与条件相反的数据,生成not取反查询语句。
3.2分页操作 firstResult和maxResults
Criteria接口提供用于分页查询的方法,实现数据库SQL物理级别的分页操作。
setFirstResult(int firstResult)设置记录的起始位置0代表第一条记录。
setMaxResults(int maxResults)设置查询记录的长度。
例如:我要查询1-10条件记录firstResult为0 ,maxResult为10。
产生的SQL语句:
3.3排序操作 Order
Hibernate提供org.hibernate.criterion.Order用于排序操作, Criteria 接口提供addOrder(Order order)用于生成排序SQL。
例如:查询所有员工信息,按照年龄升序排列。
产生的SQL语句:
Criteria接口提供createAlias 和 createCriteria 两组方法用于完成多表关联查询。
createAlias(String associationPath, String alias) 采用内连接关联。
createAlias(String associationPath, String alias, int joinType) 可以通过joinType指定连接类型。
createCriteria(String associationPath) 采用内连接关联(返回新的Criteria对象)。
createCriteria(String associationPath, int joinType) 可以通过joinType指定关联类型(返回新的Criteria对象 )。
例如:查询部门为“人力资源部”的所有员工。
方法一:使用createCriteria方法。
产生的SQL语句:
代码中的criteria对象,是针对employee表,criteria.createCriteria(”department”) 就是建立employee表和department表的内连接。返回的是针对department表新的criteria2对象,这时再对criteria2 添加条件,就是查询department部门表的属性,而不是employee的属性了。
方法二:使用createAlias 方法。
使用createAlias方法不会像createCriteria那样返回一个新的Criteria对象,alias只是对关联表进行别名设置,通过别名引用设置属性。
产生的SQL语句:
3.5.投影、分组查询 Projection
在实际开发中,进行查询是:可能只需要返回表中的指定列信息(投影)或者进行统计查询(count、avg、sum、min、max),Criteria接口提供setProjection(Projection projection)方法用于实现投影查询操作。
org.hibernate.criterion.Projections工厂类用于返回Projection投影查询对象。
例如: 1. 查询员工表的name和age属性。
产生的SQL语句:
Projections.property(属性名)也可以写为Property.forName(属性名 )。
2.查询员工的总数量。
Projections提供了分组函数的查询方法:
rowCount() 查询记录总数量;
count(String propertyName) 统计某列数量;
countDistinct(String propertyName) 统计某列数量(排除重复);
avg(String propertyName) 统计某列平均值;
sum(String propertyName) 对某列值求和;
max(String propertyName) 求某列最大值;
min(String propertyName) 求某列最小值。
产生的SQL语句:
3.查询每个部门的员工数量(输出部门的编号和数量 )。
Projections提供groupProperty(String propertyNam
-e)用于执行分组操作。
产生的SQL语句:
3.6. 设置结果集封装策略 ResultTransformer
刚刚说了投影操作的使用,其实在Hibernate内部投影查询是会影响到结果集的封装策略的。先用HQL举例说明:
session.createQuery(”from Employee”).list(); 返回 List
session.createQuery(”select count(e) from Employee e”).list(); 返回List
session.createQuery(”select name,age from Employee”).list(); 返回List<object[]>
从这几个例子我们不难发现,如果没有指定select语句(没有投影),那么将返回表中的所有字段,返回结果会被封装到Entity实体对象Employee中,一但提供select语句(投影)后,返回的结果类型,将不再封装到Employee对象,而是根据投影的实际类型返回,这就是投影对结果封装策略的影响。
我们再来看之前写过的Criteria 查询案例:
session.createCriteria(Employee.class).list();返回 List
session.createCriteria(Employee.class).setProjection(
Projections.projectionList()
.add(Property.forName(”name”))
.add(Property.forName(”age”))); 返回 List<object[]>
投影之后,返回的结果将不再被封装到Employee对象中,这是为什么呢?
我们一起来看看 Criteria的接口定义,不难发现在Criteria接口中提供了一个setResultTransformer(ResultTransformer resultTransformer),这个ResultTransformer就是结果集转换策略接口,在Criteria的父接口中CriteriaSpecification定义了几个ResultTransformer的常用实现。
ALIAS_TO_ENTITY_MAP 将结果集封装到Map对象;
ROOT_ENTITY 将结果集封装到根实体对象;
DISTINCT_ROOT_ENTITY 将结果集封装到不重复的根实体对象;
PROJECTION 根据投影的结果类型自动封装;
当进行投影查询时,结果的封装策略由ROOT_ENTITY 变为了PROJECTION, 所以是根据查询数据进行封装,而不是封装到根对象。
了解上面原理后,即使只查询name和age属性,也可以封装成List集合。
使用AliasToBeanResultTransformer 修改结果封装策略,AliasToBeanResultTransformer 会根据返回列自动匹配类中属性名,完成封装。
产生的SQL语句:
员工表 department
CREATE TABLE `employee` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(255) default NULL,
`age` int(11) NOT NULL,
`birthday` date default NULL,
`department_id` int(11) default NULL,
PRIMARY KEY (`id`),
FOREIGN KEY (`department_id`) REFERENCES `department` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2.2.使用JPA注解配置实体类
部门类 Department
员工类 Employee
2.3使用Crteria查询所有部门和所有员工
2.3.1查询所有部门
产生的SQL语句:
查询所有员工
产生的SQL语句:
当session.createCriteria(实体类.class) 就会产生一条select所有列from 表;SQL语句,查询实体类对应数据表的所有记录,然后我们就可以在这个Criteria对象上进行条件查询、分页查询、多表关联查询、投影查询、子查询等一系列操作……
3.Criteria SQL定制详解
3.1对查询添加条件对象Criterion
org.hibernate.criterion.Criterion是Hibernate提供的一个面向对象查询条件接口,一个单独的查询就是Criterion接口的一个实例,用于限制Criteria对象的查询,在Hibernate中Criterion对象的创建通常是通过Restrictions 工厂类完成的。
Restrictions 提供条件查询方法:
例如:
1、查询姓“张”的所有员工信息
产生的SQL语句:
2、查询年龄大于24的所有员工
产生的SQL语句:
3、查询年龄小于28的姓“王”的员工
产生的SQL语句:
对于多个查询条件,Restrictions提供了逻辑组合查询方法。
and(Criterion lhs, Criterion rhs) 用于生成多个条件and关系SQL语句;
or(Criterion lhs, Criterion rhs) 用于生成多个条件or关系SQL语句;
not(Criterion expression) 用于查询与条件相反的数据,生成not取反查询语句。
3.2分页操作 firstResult和maxResults
Criteria接口提供用于分页查询的方法,实现数据库SQL物理级别的分页操作。
setFirstResult(int firstResult)设置记录的起始位置0代表第一条记录。
setMaxResults(int maxResults)设置查询记录的长度。
例如:我要查询1-10条件记录firstResult为0 ,maxResult为10。
产生的SQL语句:
3.3排序操作 Order
Hibernate提供org.hibernate.criterion.Order用于排序操作, Criteria 接口提供addOrder(Order order)用于生成排序SQL。
例如:查询所有员工信息,按照年龄升序排列。
产生的SQL语句:
Criteria接口提供createAlias 和 createCriteria 两组方法用于完成多表关联查询。
createAlias(String associationPath, String alias) 采用内连接关联。
createAlias(String associationPath, String alias, int joinType) 可以通过joinType指定连接类型。
createCriteria(String associationPath) 采用内连接关联(返回新的Criteria对象)。
createCriteria(String associationPath, int joinType) 可以通过joinType指定关联类型(返回新的Criteria对象 )。
例如:查询部门为“人力资源部”的所有员工。
方法一:使用createCriteria方法。
产生的SQL语句:
代码中的criteria对象,是针对employee表,criteria.createCriteria(”department”) 就是建立employee表和department表的内连接。返回的是针对department表新的criteria2对象,这时再对criteria2 添加条件,就是查询department部门表的属性,而不是employee的属性了。
方法二:使用createAlias 方法。
使用createAlias方法不会像createCriteria那样返回一个新的Criteria对象,alias只是对关联表进行别名设置,通过别名引用设置属性。
产生的SQL语句:
3.5.投影、分组查询 Projection
在实际开发中,进行查询是:可能只需要返回表中的指定列信息(投影)或者进行统计查询(count、avg、sum、min、max),Criteria接口提供setProjection(Projection projection)方法用于实现投影查询操作。
org.hibernate.criterion.Projections工厂类用于返回Projection投影查询对象。
例如: 1. 查询员工表的name和age属性。
产生的SQL语句:
Projections.property(属性名)也可以写为Property.forName(属性名 )。
2.查询员工的总数量。
Projections提供了分组函数的查询方法:
rowCount() 查询记录总数量;
count(String propertyName) 统计某列数量;
countDistinct(String propertyName) 统计某列数量(排除重复);
avg(String propertyName) 统计某列平均值;
sum(String propertyName) 对某列值求和;
max(String propertyName) 求某列最大值;
min(String propertyName) 求某列最小值。
产生的SQL语句:
3.查询每个部门的员工数量(输出部门的编号和数量 )。
Projections提供groupProperty(String propertyNam
-e)用于执行分组操作。
产生的SQL语句:
3.6. 设置结果集封装策略 ResultTransformer
刚刚说了投影操作的使用,其实在Hibernate内部投影查询是会影响到结果集的封装策略的。先用HQL举例说明:
session.createQuery(”from Employee”).list(); 返回 List
session.createQuery(”select count(e) from Employee e”).list(); 返回List
session.createQuery(”select name,age from Employee”).list(); 返回List<object[]>
从这几个例子我们不难发现,如果没有指定select语句(没有投影),那么将返回表中的所有字段,返回结果会被封装到Entity实体对象Employee中,一但提供select语句(投影)后,返回的结果类型,将不再封装到Employee对象,而是根据投影的实际类型返回,这就是投影对结果封装策略的影响。
我们再来看之前写过的Criteria 查询案例:
session.createCriteria(Employee.class).list();返回 List
session.createCriteria(Employee.class).setProjection(
Projections.projectionList()
.add(Property.forName(”name”))
.add(Property.forName(”age”))); 返回 List<object[]>
投影之后,返回的结果将不再被封装到Employee对象中,这是为什么呢?
我们一起来看看 Criteria的接口定义,不难发现在Criteria接口中提供了一个setResultTransformer(ResultTransformer resultTransformer),这个ResultTransformer就是结果集转换策略接口,在Criteria的父接口中CriteriaSpecification定义了几个ResultTransformer的常用实现。
ALIAS_TO_ENTITY_MAP 将结果集封装到Map对象;
ROOT_ENTITY 将结果集封装到根实体对象;
DISTINCT_ROOT_ENTITY 将结果集封装到不重复的根实体对象;
PROJECTION 根据投影的结果类型自动封装;
当进行投影查询时,结果的封装策略由ROOT_ENTITY 变为了PROJECTION, 所以是根据查询数据进行封装,而不是封装到根对象。
了解上面原理后,即使只查询name和age属性,也可以封装成List集合。
使用AliasToBeanResultTransformer 修改结果封装策略,AliasToBeanResultTransformer 会根据返回列自动匹配类中属性名,完成封装。
产生的SQL语句:
相关推荐
### Hibernate Criteria 查询详解 #### 一、概述 Hibernate Criteria 查询是一种强大的对象化查询方式,它为开发者提供了一种灵活而直观的方式来构建复杂的查询逻辑。与传统的SQL查询相比,Criteria查询更加面向...
### Hibernate Criteria 排序问题详解 #### 一、前言 在使用Hibernate进行数据库操作时,经常需要对查询结果进行排序处理。对于简单的查询场景,使用HQL(Hibernate Query Language)即可轻松实现排序功能;但对于...
### Hibernate Criteria 分组、排序与关联查询详解 #### 标题与描述理解 - **标题**:“hibernate criteria 分组 排序 关联”这一标题明确了本文将围绕Hibernate Criteria API进行分组、排序以及关联查询的具体...
《精通Hibernate:Java对象持久化详解》是一本深入解析Hibernate技术的专著,它主要针对Java开发者,旨在帮助他们理解和掌握Java对象持久化的精髓。Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了...
总的来说,Hibernate的Criteria API提供了一种声明式的查询方式,使得开发者能够以面向对象的方式构建查询,增加了代码的可读性和可维护性,同时减少了SQL注入的风险。理解和熟练掌握Criteria API,对于提高在...
【Hibernate Criteria 用法详解】 Hibernate Criteria API 是一种面向对象的查询方式,它提供了一种比HQL(Hibernate Query Language)更为简洁且直观的查询手段。通过Criteria API,开发者可以构建复杂的查询条件...
**Hibernate Criteria 完全使用详解** Hibernate Criteria API 是 Hibernate 框架中一个强大的查询工具,它提供了一种面向对象的方式来构建SQL查询,使得开发者无需直接编写SQL语句,即可进行复杂的数据库操作。...
### Hibernate Criteria 使用方法详解 #### 一、简介 Hibernate 是一款非常流行的 Java 持久层框架,它简化了对象关系映射(ORM)过程中的许多复杂性。在 Hibernate 中,Criteria API 提供了一种类型安全的方式来...
在Java世界中,Hibernate是一个非常流行的对象关系映射(ORM)框架,它简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据。本篇将详细解析Hibernate的配置文件,帮助你深入理解其工作原理和配置过程。 ...
《精通Hibernate:Java对象持久化技术详解》这本书深入剖析了Hibernate这一流行的Java对象关系映射(ORM)框架,旨在帮助开发者全面理解并熟练掌握Hibernate的使用。Hibernate是Java开发中的重要工具,它简化了...
**Hibernate详解** Hibernate是一款强大的Java持久化框架,它简化了数据库与Java对象之间的交互,使得开发者无需关注SQL的编写,可以更加专注于业务逻辑。本文将深入探讨Hibernate的核心概念、主要功能以及如何在...
**hibernate包详解** Hibernate 是一款开源的对象关系映射(ORM)框架,它为Java开发者提供了一种在关系数据库和面向对象编程之间架起桥梁的解决方案。通过使用Hibernate,开发人员可以避免直接编写SQL语句,而是用...
《Hibernate中文开发详解》是针对Hibernate框架的一份详尽指南,旨在帮助开发者深入了解并掌握这一持久化技术。本文将基于给定的标题、描述、标签和部分内容,深度解析Hibernate的关键概念与开发技巧。 ### ...
**关联映射Hibernate的Criteria用法详解** 在Java开发中,Hibernate作为一种强大的对象关系映射(ORM)框架,极大地简化了数据库操作。其中,Criteria API是Hibernate提供的一个动态查询工具,它允许开发者以面向...
在“hibernate:java持久化对象详解02”中,你可能会接触到更复杂的查询技巧,如联接查询、子查询、分页查询等,以及如何使用 Criteria API 来实现这些查询。同时,可能会讲解到级联操作(Cascade)、懒加载(Lazy ...
《精通Hibernate:Java对象持久化技术详解》一书聚焦于Java开发中的对象持久化技术,主要围绕Hibernate这一流行ORM框架进行深入探讨。Hibernate是Java世界里的重要工具,它简化了数据库操作,使得开发者可以更加专注...
### Java Hibernate Criteria 使用详解 #### 一、简介与应用场景 在Java开发中,特别是涉及到数据库操作时,Hibernate作为一款优秀的对象关系映射(ORM)工具,提供了多种查询方式,其中包括了HQL(Hibernate ...
### Hibernate详解:从入门到精通 #### 概述与核心概念 Hibernate,一款由Gavin King创立并发展的开源对象关系映射(Object Relational Mapping,简称ORM)框架,旨在简化Java应用程序与数据库交互的复杂度。它...
### Hibernate-Criteria 模糊查询详解 在Java的持久化技术中,Hibernate作为ORM(对象关系映射)框架的一种,提供了强大的数据访问能力。而其中的`Criteria`接口更是为复杂的查询需求提供了一种灵活且功能强大的...