浅谈Hibernate中HQL查询需要注意的几点

开发 后端
本文将介绍Hibernate中HQL查询需要注意的几点,HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式。

一、Hibernate对象的HQL查询

Sql代码

  1. select  u from User  u    
  2. select  u from User  u return:List<User> 

返回的是装有持久化对象的List集合  ,持久化对象,在session中,受session生命周期的管理,只要session不关闭,就存在。

二、Hibernate属性的HQL查询

Sql代码

  1. select u.id,u.name ,u.email from User u    
  2. select u.id,u.name ,u.email from User u   
  3. return : List<Object[]> 

返回的是普通JavaBean对象

1:不占用Hibernate的session缓存,只要被检索之后,应用程序不在访问他们,垃圾回收器就会回收。

2:Hibernate不会对他们进行同步修改,因为Hibernate是更据内存中的状态更新数据的(和DB交互)

三、Hibernate自定义的HQL查询

Sql代码

  1. select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c    
  2.  
  3. select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c 

这种是你一定要返回一个对象是,而且这些属性来自不同的表,

需要注意的是:new的对象一定要是:全路径

四、其他

  1. select u.name from User u 

返回的是List  这是不需要返回任何对象时,只要要返回String即可,

关键点二和四可以叫投影查询,这种效率更高

【编辑推荐】

  1. Hibernate中generator属性的意义
  2. hibernate Key Generator 主键生成方式
  3. Hibernate的主键生成机制
  4. hibernate的Query cache
  5. Hibernate中hbm的generator属性
责任编辑:彭凡 来源: javaeye
相关推荐

2009-06-22 13:46:00

java程序员考试

2009-08-28 09:26:35

C#连接Access

2009-08-11 14:32:06

C#读取Excel数据

2009-06-18 09:14:08

Hibernate H

2009-09-25 16:57:49

Hibernate查询

2009-09-23 18:05:48

2011-05-12 09:01:29

HTML5

2009-06-12 15:32:01

Hibernate H

2009-06-30 10:10:15

Namespace用法Flex

2010-04-22 12:07:37

Oracle Spat

2011-05-26 17:37:11

Ajax

2013-09-03 13:01:01

团队管理团队

2013-09-29 10:36:08

VMware虚拟化

2009-04-23 14:30:19

UML建模

2020-10-26 14:01:22

Java泛型

2009-06-26 16:09:21

Hibernate查询HQL

2010-07-12 13:00:49

UML建模

2009-06-10 15:36:25

ubuntu netb开发过程

2010-08-31 14:33:46

DB2游标

2009-12-25 15:47:20

ADO存储过程
点赞
收藏

51CTO技术栈公众号