一、Hibernate对象的HQL查询
Sql代码
- select u from User u
- select u from User u return:List<User>
返回的是装有持久化对象的List集合 ,持久化对象,在session中,受session生命周期的管理,只要session不关闭,就存在。
二、Hibernate属性的HQL查询
Sql代码
- select u.id,u.name ,u.email from User u
- select u.id,u.name ,u.email from User u
- return : List<Object[]>
返回的是普通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
- select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c
这种是你一定要返回一个对象是,而且这些属性来自不同的表,
需要注意的是:new的对象一定要是:全路径
四、其他
- select u.name from User u
返回的是List
关键点二和四可以叫投影查询,这种效率更高
【编辑推荐】