原文地址:
http://blog.csdn.net/sun8288/article/details/8132181
Hibernate 是JDBC的轻量级封装,一款杰出的ORM框架。通过它,可以建立数据表与表对象间的联系。
Hibernate的查询可通过HQL 和Criteira实现。本文仅展示用HQL实现多表查询,并针对返回的结果集进行对象封装。
如果我们在Hibernate中需要查询多个表的不同字段,那么如何来获取Hibernate多表查询的结果呢?有两种方式:
1、 利用Hibernate重写的List,从Obeject[ ]中取各个字段分别转化成对应类型,如下:
Query q = session.createQuery(" select members, classInfo.className " +
" from Members members, ClassInfo classInfo " +
" where members.level = classInfo.classCode ");
List result = q.list();
Iterator it = result.iterator();
while (it.hasNext()) {
Object[] tuple = (Object[]) it.next();
Members members = (Members) tuple[ 0 ];
String className = (String) tuple[ 1 ];
}
这是获取Hibernate多表查询的结果的最常用的方式,利用Hibernate为了实现懒加载重写所有Collection接口实现。
2、构造自己的复合类型,如下:
Query q = session.createQuery
(" select new ${pkg}.NewMembers(members, classInfo.className) " +
" from Members members, ClassInfo classInfo " +
" where members.level = classInfo.classCode ");
Query q = session.createQuery
(" select new NewMembers(members, classInfo.className)
" + " from Members members, ClassInfo classInfo " + "
where members.level = classInfo.classCode ");
当然我们需要有一个NewMembers类和相应的构造方式。
需要特别指出的是,定义的复核类型NewMembers务必要实现java.io.Serializable接口,定义相应的构造方法:一个默认不带参数的,一个根据需要带参数的(通常是全参,呵呵,因为本身成员变量就是量身定制);此外,在使用中,发现必须指定自定义类型的完整类名${pkg}.NewMembers,${pkg}为NewMembers的包名。
第二种方法显然扩展性更好。
分享到:
相关推荐
hibernate多表联合查询实例,很经典的查询语句和总结.
hibernate 多表查询 hibernate 多表不同于一般的sql嵌套查询,嵌套查询是不支持的,所以必须要配置好才能实现多表!只要配置好了,还是特别好用的
Hibernate连表查询 Hibernate连表查询
Hibernate 多表连接分页查询示范项目 Hibernate Criteria 多表连接 分页
该源代码配了了解释,针对hibernate中多表查询的多种形式进行了总结,很有价值,有Object[]形式的查询,也有对象方式的查询 也有集合list形式的查询,
Hibernate 多表映射关系配置 如,一对一 多对一 多对多等
Hibernate多表查询.txt
hibernate多表查询[定义].pdf
hibernate 中间表 希望给予新手帮助
Hibernate多表关联配置及错误解决方法,及时更新,相关信息待下回分解!
Hibernate多对多关联添加及查询示例
Hibernate_query查询数据表中的一个字段.
Hibernate_QBC查询
NULL 博文链接:https://08284008.iteye.com/blog/1456476
Hibernate SQLQuery 查询Oracle char类型结果为一个字符解决方法 Hibernate SQLQuery 查询Oracle char类型结果为一个字符解决方法 Hibernate SQLQuery 查询Oracle char类型结果为一个字符解决方法 Hibernate SQL...
Hibernate中的关联查询实际上生成的是数据库表连接查询的SQL语句
Hibernate中使用Criteria Query各种QBC查询
NULL 博文链接:https://gaoquanyang.iteye.com/blog/1213765
使用Struts2+Hibernate实现对部门表、员工表两张表的增删改查。
Hibernate的查询方式Hibernate的查询方式