继承映射
subclass:子类父类一张表
person为父类student为子类
在person.hbm.xml文件中
1.对于子类对象只需把记录插入到一张数据表中
2.辨别者列有hibernate自动维护
查询:
1.查询父类记录,只需要查询一张数据表
2.对于子类记录,也只需要查询一张数据表
缺点:
1.使用了辨别者列。
2.子类独有的字段不能添加非空约束
3.若继承层次较深,则数据表的字段也会较多
-----
joined-subclass :子类独有一张表
1.对于子类对象需要插入到至少两张数据表中,性能较差一些。
查询:
1.查询父类记录,做一个左外连接查询
2.对于子类记录,做一个内连接查询(性能差一些)
优点:
1.不需要使用辨别者列。
2.子类独有的字段能添加非空约束
3.没有冗余的字段
------
union-subclass:将每一个实体对象映射到一个独立的表
1.对于子类对象只需把记录插入到一张数据表中
查询:
1.查询父类记录,需把父类和子表记录汇总到一起在做查询,性能稍差。
2.对于子类记录,也只需查询一张数据表
优点:
1.不需要使用辨别者列。
2.子类独有的字段能添加非空约束
缺点:
1.有冗余的字段
2.若更新父表的字段,则更新效率较低
subclass:子类父类一张表
person为父类student为子类
在person.hbm.xml文件中
<class name="Person" table="PERSONS" discriminator-value="PERSON">
<!--配置辨别者列-->
<discriminator column="TYPE" type="string"></discriminator>
<!--映射子类Student,使用subclass进行映射-->
<subclass name="Student" discriminator-value="STUDENT" >
<property name="school" type="string" column="SCHOOL"></property>
</subclass>
插入操作:
1.对于子类对象只需把记录插入到一张数据表中
2.辨别者列有hibernate自动维护
查询:
1.查询父类记录,只需要查询一张数据表
2.对于子类记录,也只需要查询一张数据表
缺点:
1.使用了辨别者列。
2.子类独有的字段不能添加非空约束
3.若继承层次较深,则数据表的字段也会较多
-----
joined-subclass :子类独有一张表
<joined-subclass name="Student" table="STUDENTS">
<key column="STUDENT_id"></key>
<property name="school" type="string" column="SCHOOL"></property>
</joined-subclass>
插入操作:
1.对于子类对象需要插入到至少两张数据表中,性能较差一些。
查询:
1.查询父类记录,做一个左外连接查询
2.对于子类记录,做一个内连接查询(性能差一些)
优点:
1.不需要使用辨别者列。
2.子类独有的字段能添加非空约束
3.没有冗余的字段
------
union-subclass:将每一个实体对象映射到一个独立的表
<union-subclass name="Student" table="STUDENTS">
<property name="school" column="SCHOOL" type="string"></property>
</union-subclass>
插入操作:
1.对于子类对象只需把记录插入到一张数据表中
查询:
1.查询父类记录,需把父类和子表记录汇总到一起在做查询,性能稍差。
2.对于子类记录,也只需查询一张数据表
优点:
1.不需要使用辨别者列。
2.子类独有的字段能添加非空约束
缺点:
1.有冗余的字段
2.若更新父表的字段,则更新效率较低