方式一:建立视图
像查询表一样查询视图,给视图建立持久化类。
方式二:建立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;