Hibernate的继承映射

                                       Hibernate的继承映射

        在一个类层次映射成一个表时,定义的discriminator只在hibernate与数据库之间使用。在持久化类中并不需要定义discriminator字段,即使定义了,而且数据库中该字段不为空,程序中访问该字段也将得到null值。也就是说,discriminator对应用程序是不可见的。从DTD里也可以看出,discriminator没有name元素,也就是说持久化类中不必为相应column定义一个属性。hibernate根据对象的具体类并参照映射文件中的discriminator字段来确定数据库中记录的更新、保存以及加载。采用这种策略只需要一张表即可。它有一个很大的限制:要求那些由子类定义的字段,不能有非空(NOT NULL)约束。

        在每个子类一张表时,连同超类,按照下面的实例,数据库中需要三张表。子类表通过主键关联到超类表(因而关系模型实际上是一对一关联)。子类中 的idPayment在数据库中可以设置成主键。

1、一个类层次对应一个表

< hibernate-mapping >
    
< class  name ="com.persistent.Payment"  table ="payment"   >     
        
< id  name ="id"  column ="paymentId"  unsaved-value ="null" >
            
< generator  class ="increment" ></ generator >
        
</ id >         
        
< discriminator  column ="paymentType" ></ discriminator >         
        
< property  name ="amount"  column ="amount" ></ property >         
        
< subclass  name ="com.persistent.CashPayment"  discriminator-value ="cash" >
            
< property  name ="cashType"  column ="cashType" ></ property >
        
</ subclass >         
        
< subclass  name ="com.persistent.CardPayment"  discriminator-value ="card" >
            
< property  name ="cardNumber"  column ="cardNumber" ></ property >
        
</ subclass >     
    
</ class >
</ hibernate-mapping >

2、每个子类一张表

< hibernate-mapping >
    
< class  name ="com.persistent.Payment"  table ="payment"   >     
        
< id  name ="id"  column ="paymentId"  unsaved-value ="null" >
            
< generator  class ="increment" ></ generator >
        
</ id >         
        
< property  name ="amount"  column ="amount" ></ property >         
        
< joined-subclass  name ="com.persistent.CashPayment"  table ="cashpayment" >
            
< key  column ="idPayment" ></ key >
            
< property  name ="cashType"  column ="cashType" ></ property >
        
</ joined-subclass >         
        
< joined-subclass  name ="com.persistent.CardPayment"  table ="cardpayment" >
            
< key  column ="idPayment" ></ key >
            
< property  name ="cardNumber"  column ="cardNumber" ></ property >
        
</ joined-subclass >     
    
</ class >
</ hibernate-mapping >

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值