Hibernate学习笔记(六)【映射继承关系】

     场景有个User类,然后扩展出了Student类和Teacher类,也就是Student类和Teacher类继承了User类 

  1. 数据库是这样设计的,给每个子类造了一个表,下面是Hibernate项目配置,只配User

    <class name="User"abstract="true">
     <id name="id" column="USER_ID" type="long">
      <generator class="native"></generator>
     </id>
     <property name="name" column="USER_NAME" type="string"></property>
     <union-subclass name="Teacher" table="TEACHER">
      <property name="job" column="TEACHER_JOB"/>
     </union-subclass>
     <union-subclass name="Student" table="STUDENT">
      <property name="class" column="STUDENT_CLASS"/>
     </union-subclass>
    </class>

    用法就是存储查询Teacher、Student都可以;如果查全的也行User,数据库发的是union语句

  2.  尼玛整个各种子类和他们的父类都在一张表,同时搞个字段区分是哪个类。配置文件这么写:

     <class name="User"table="USERS">
     <id name="id" column="USER_ID" type="long">
      <generator class="native"></generator>
     </id>
     <discrimnator column="DISCRIMNATOR" type="String"></discrimnator>
     <property name="name" column="USER_NAME" type="string"></property>
     <subclass name="Teacher" discrimnator-value="TEACHER">
      <property name="job" column="TEACHER_JOB"/>
     </subclass>
     <subclass name="Student" discrimnator-value="STUDENT">
      <property name="class" column="STUDENT_CLASS"/>
     </subclass>
    </class>

    父类如果不是抽象类,也可以在<class>表情内部搞个discrimnator-value="某某",这样父类子类任意搞

  3. 父类对应一张表,每子类再各自对应一张表,子类表的主键也是外键,就是说子类id=2,和父类里面有个id=2的组合用,多了个key配。配置文件这么写的:

     <class name="User"table="USERS">
     <id name="id" column="USER_ID" type="long">
      <generator class="native"></generator>
     </id> 
     <property name="name" column="USER_NAME" type="string"></property>
     <joined-subclass name="Teacher" table="TEACHER">
      <key column="TEACHER_ID"/>
      <property name="job" column="TEACHER_JOB"/>
     </joined-subclass>
     <joined-subclass name="Student" table="STUDENT">
      <key column="STUDENT_ID"/>
      <property name="class" column="STUDENT_CLASS"/>
     </joined-subclass>
    </class>

  4. 虽然原则上上述方法是不能混用的,但实际上使用外连接也是可以结合使用的,但是个人认为不太好,除非万不得已,最好不要使用,参考《Hibernate in action》208页。

    区别嘛,都标红了,数据库的区别,可以看看标红的类对应表没,至于用哪种,你觉得用起来哪种舒服就那种。有时候都不搞继承,当字段区分搞了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值