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

一、Hibernate对象的HQL查询

Sql代码

select  u from User  u    
<!--CRLF-->
select  u from User  u return:List<User> 
<!--CRLF-->

二、Hibernate属性的HQL查询

Sql代码

select u.id,u.name ,u.email from User u    
<!--CRLF-->
select u.id,u.name ,u.email from User u   
<!--CRLF-->
return : List<Object[]> 
<!--CRLF-->
 

返回的是普通JavaBean对象

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

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

三、Hibernate自定义的HQL查询

Sql代码

select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c     
<!--CRLF-->
select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c 
<!--CRLF-->
 

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

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

四、其他

select u.name from User u 
<!--CRLF-->

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

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

你可能感兴趣的:(Hibernate)