根据类分层结构设计Hibernate Mapping与数据库表结构

首先,有三个实体对象User,Student, Teacher

其中三者共同的属性是name,password,fullname,均定义在User中,Student和Teacher继承User

用每个类分层的方式进行mapping映射,只需要用到一个表userinfo就可以描述以上关系

但需要增加一个user_type字段

 

< class  table ="userinfo"  name ="cn.hxex.exam.model.User" >
  
< id  name ="id"  column ="ID" >
      
< generator  class ="uuid.hex" />
   
</ id >
    
< property  name ="name"  column ="NAME" />
    
< property  name ="password"  column ="PASSWORD" />
    
< property  name ="fullname"  column ="FULLNAME" />
     
     
< subclass  name ="cn.hxex.exam.model.Student"  discriminator-value ="student" >
          
< many-to-one  column ="CLASS_ID"  cascade ="save-update"  name ="classes" />
     
< subclass >
      
< subclass  name ="cn.hxex.exam.model.Teacher“ discriminator-value=" teacher" >
          
< set  cascade ="all"  lazy ="true"  table ="TEACHER_CLASS"  name ="classes" >
             
< key  column ="TEACHER_ID" />
              
< many-to-many  class ="cn.hxex.exam.model.Classes"  column ="CLASS_ID" />
           
</ set >
       
< subclass >
</ class >

 当执行from User 时候,只需要执行select * from userinfo ,可以减少sql执行次数

 当执行from Student ,hibernate会自动执行select * from userinfo where user_type="student";

同样,在进行对象持久话操作时,也会根据对象类型自动设置user_type字段值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值