Hibernate关联查询有多种实现方式
方式一:建立视图
像查询表一样查询视图,给视图建立持久化类。
方式二:建立POJO之间的互相引用
在*.hbm或Annotation中配置"subclass"属性,对应三种类型的关联方式one-to-one/many-to-one/one-to-many.
需要谨慎的使用Lazy和fetch关键字,避免不必要的查询,或者已经关闭Session后再查询。
方式三:直接查询,将结果保存在临时对象中
比如有存在关联的表A和表B字段分别如下
A:id,aName,aDesc
B:id,aId,bName,bDesc
希望查询的结果是:A.id,B.id,A.aName,B.bName,B.bDesc
按照如下步骤操作:
1.创建A和B的hibernate映射,相互不用关联,对应持久化类为APojo和BPojo
2.创建结果集的载体CPojo,CPojo只是简单的一个JavaBean不是持久化类,它的属性与查询结果相对应:
public class CPojo {
public long aId;
public long bId;
public String aName;
public String bName;
public String bDesc;
public CPojo(long aId, long bId, String aName, String bName, String bDesc) {
this.aId = aId;
this.bId = bId;
this.aName = aName;
this.bName = bName;
this.bDesc = bDesc;
}
}
3.HQL写法:
Select new com.XXX.CPojo(a.id,b.id,a.aName,b.bName,b.bDesc) from A a,B b where a.id = b.aId
4.执行HQL获取结果集
这种方式的优点:不需要建立复杂的持久化类,也不需要建立视图。结果集可以自由定制。
需要注意的几点:
1.CPojo必须把包名写上,因为CPojo并不是持久化类,Hibernate不能自动匹配。否则运行时异常,无法找到Class。
2.CPojo必须存在以上使用的构造函数(这好像是废话)。
3.该HQL语句不会自动拆装箱,比如APojo.id在映射文件中是Long型,但CPojo的构造函数里是aId是long型,则运行时抛出异常无法找到构造函数。
在这里顺便说一个Hibernate的小Bug,属性aId如果是在持久化类中,则Hibernate会找不到相应的getter和setter,原因是自动生成的getAId或setAId不符合Hibernate默认读取getter和setter的规则即:get后的两个字母第一个必须大写,第二个必须小写。所以尽量避免在持久化类中使用aId(第二个字母大写)这种类型的命名
。
分享到:
相关推荐
hibernate关联查询 实例源码 java web 如果不明白hibernate关联查询不明白的可以看看,保证马上学会,注释,数据库都有,很简单易学的源码,谢谢下载!
hibernat一对多关联查询。。。。。。。。。。。。。。
hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,包含4个说明文档,分别详细解说了hibernate关联映射的...
Hibernate中的关联查询实际上生成的是数据库表连接查询的SQL语句
Hibernate 一对一外键单向关联 Hibernate 一对一主键单向关联 Hibernate 一对一连接表单向关联 Hibernate 一对多外键单向关联 Hibernate 一对多连接表单向关联 Hibernate 多对一外键单向关联 Hibernate 多对一连接...
该资源包含了一些常用的hibernate关联映射实例。包括一对多,多对多,继承映射,等,是学习hibernate的必备品
Hibernate关联关系练习【全】
hibernate关联关系
关于hibernate的关联操作 分享下
映射一对多关联关系 以Customer和Order为例: 一对多: 每个Customer可以有一个或者多个Order,因此Customer中应该有一个集合类型的属性,来引用所有关联的Order对象。 多对一。全实例讲解
Hibernate关联关系映射 单向关联 │ ├─ 一对一外键单向关联 │ ├─ 一对一主键单向关联 │ ├─ 一对一连接表单向关联 │ ├─ 一对多外键单向关联 │ ├─ 一对多连接表单向关联 │ ├─ 多对一外键单向关联 │ ...
Hibernate 关联关系映射分类
详细讲解hibernate的关联关系,以及用实例讲解,非常详细
Hibernate中的查询方法若HQL,详细讲解HQL与使用的具体例子
hibernate多表联合查询实例,很经典的查询语句和总结.
关于对Hibernate关联映射的一个总结,其中有各种映射的例子,详细用法 等
Hibernate关联关系.docHibernate关联关系.doc
文件中包含关于hibernate 各个属性的解释
Hibernate关联关系总结 一对多 多对一 多对多