Hibernate3 之 继承映射

本文介绍了Hibernate中两种不同的继承映射策略:一种是父类和子类共用一张表,通过类型判别器进行区分;另一种是每个子类各自拥有一张表,主键与父类表关联。这两种策略各有优劣,适用于不同的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 父类和子类 公用一张表:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.ethan.domain">
	<class name="Employee" discriminator-value="0">
		<id name="id">
			<generator class="native"/>
		</id>
		
		<discriminator column="tyep" type="java.lang.Integer"></discriminator>
		<!-- name unique -->
		<property name="name"/>
		
		<!-- departId外键参考department表 -->
		<many-to-one name="depart" column="departId"/>		
		
		<subclass name="Skiller" discriminator-value="1">
			<property name="skill"></property>
		</subclass>
		
		<subclass name="Sales" discriminator-value="2">
			<property name="sell"></property>
		</subclass>
	</class>
</hibernate-mapping>

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.ethan.domain">
	<class name="Department">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<!-- name unique -->
		<property name="name"/>
		<!-- 如果是delete,那么部门删除时,它下边的员工也会跟着删除 -->
		<set name="emps" inverse="true" cascade="save-update">
			<key column="departId"></key>
			<one-to-many class="Employee"/>
		</set>
	</class>
</hibernate-mapping>

2.子类 各自一张表,主键参考父类主键,父类表中存放 公有字段:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.ethan.domain">
	<class name="Employee">
		<id name="id">
			<generator class="native"/>
		</id>
		
		<!-- <discriminator column="type" type="java.lang.Integer"></discriminator> -->
		<!-- name unique -->
		<property name="name" unique="true"/>
		
		<!-- departId外键参考department表 -->
		<many-to-one name="depart" column="departId"/>		
		
		<!-- <subclass name="Skiller" discriminator-value="1">
			<property name="skill"></property>
		</subclass>
		
		<subclass name="Sales" discriminator-value="2">
			<property name="sell"></property>
		</subclass> -->
		
		<joined-subclass name="Skiller" table="skiller">
			<key column="emp_id"/><!-- 引用的是id -->
			<property name="skill"></property>
		</joined-subclass>
		
		<joined-subclass name="Sales" table="sales">
			<key column="emp_id"/><!-- 引用的是id -->
			<property name="sell"></property>
		</joined-subclass>
		
		
	</class>
</hibernate-mapping>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值