首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Linux频道
中国IT教育
Google
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 资讯动态 >> 正文

精通Hibernate之映射继承关系(六)

  Company与Employee类之间为一对多多态关联关系,如果继承关系树的根类对应一个表,或者每个类对应一个表,那么就能映射Company类的employees集合。本节介绍如何映射多对一多态关联。如图14-11所示,ClassD与ClassA为多对一多态关联关系。

  图14-11 ClassD与ClassA为多对一多态关联关系

  ClassA、ClassB和ClassC构成了一棵继承关系树,如果继承关系树的根类对应一个表,或者每个类对应一个表,那么可以按以下方式映射ClassD的a属性:

  <many-to-one name="a"

  class="ClassA"

  column="A_ID"

  cascade="save-update" />

  假定与ClassD对应的表为TABLE_D,与ClassA对应的表为TABLE_A,在TABLE_D中定义了外键A_ID,它参照TABLE_A表的主键。

  ClassD对象的a属性既可以引用ClassB对象,也可以引用ClassC对象,例如:

tx = session.beginTransaction();
ClassD d=(ClassD)session.get("ClassD",id);
ClassA a=d.getA();
if(a instanceof ClassB)
  System.out.println(((ClassB)a).getB1());
if(a instanceof ClassC)
  System.out.println(((ClassC)a).getC1());
tx.commit();

  以下代码在映射ClassD类的a属性时使用了延迟检索策略:

<many-to-one name="a"
class="ClassA"
column="A_ID"
lazy="true"
cascade="save-update" />

  当Hibernate加载ClassD对象时,它的属性a引用ClassA的代理类实例,在这种情况下,如果对ClassA的代理类实例进行类型转换,会抛出ClassCastException:

  ClassA a=d.getA();

  ClassB b=(ClassB)a; //抛出ClassCastException

  解决以上问题的一种办法是使用Session.load()方法:

  ClassA a=d.getA();

  ClassB b=(ClassB)session.load(ClassB.class,a.getId());

  System.out.println(b.getB1());

  当执行Session的load()方法时,Hibernate并不会访问数据库,而是仅仅返回ClassB的代理类实例。这种解决办法的前提条件是必须事先知道ClassD对象实际上和ClassA的哪个子类的对象关联。

[1] [2] 下一页

【责编:John】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 社区讨论
 博客论点