Hibernate"discriminator-value"用法

转自:https://blog.csdn.net/iteye_3357/article/details/81862615

 

 

 1 可能经常遇到这样的情况:
 2 
 3        在数据库表中会有这样的一个字段用来区别记录的属性,如:在客户表中有一个字段表示客户级别,当这个记录为A时是一级客户,为B时是二级客户。在用hiberante做OR表示时类可能是这样的:
 4 
 5        public class Customer{
 6 
 7           private String flag;   //表示客户的级别
 8 
 9           ...
10 
11  } 12 13  然后,在程序中手动控制flag的值,但是这样当每个级的客户有不同的属性时Customer类将包含所有级别的属性,这样不是很好。 14 15  hibernate提供一个Discriminator映射的方法,就是把一个表映射成不同的类,有不同的属性。 16 17  public class Customer{ 18 19  //包含所有级别的公共属性 20 21  ... 22 23  } 24 25 26 27  public class CustomerA extends Customer{ 28 29  //只包括一级客户的特有属性 30 31  } 32 33  public class CustomerB extends Customer{ 34 35  //只包含二级客户特有的属性 36 37  } 38 39 这样更符合面向对象的原则,然后在hbm.xml中这样写: 40 41 <id name="id" type="int"> 42 43  ... 44 45 </id> 46 47 <discriminator column="flag" type="string" /> 48 49 <!-- 公共属性的映射 --> 50 51 <subclass name="CustomerA" discriminator-value="A"> 52 53 <!-- 一级客户特有属性的映射 --> 54 55 </subclass> 56 57 <subclass name="CustomerB" discriminator-value="B"> 58 59 <!-- 二级客户特有属性的映射 --> 60 61 </subclass> 62 63 这样就可以单独的用CustomerA,CustomerB这样的实例了,做数据库修改时就不用关心flag字段的值了,会自动的加A或B。 64 65 如果是使用hibernate Annotation而不是xml来描述映谢关系,代码如下: 66 67 @Entity 68 69 @Table(name = "customer") 70 71 @Inheritance(strategy = InheritanceType.SINGLE_TABLE) 72 73 @DiscriminatorColumn(name = "flag", discriminatorType = DiscriminatorType.STRING) 74 75 public class Customer{ 76 77 } 78 79 @Entity 80 81 @DiscriminatorValue(value = "A") 82 83 public class CustomerA extends Customer{ 84 85 } 86 87 @Entity 88 89 @DiscriminatorValue(value = "B") 90 91 public class CustomerB extends Customer{ 92 93 } 94 95 这样就可以了。

 

 

2.

 1 public class Singer {
 2     private String region;
 3     private Long id;
 4     private Set<Song> songs = new HashSet<Song>();
 5 
 6     public String getRegion() {
 7         return region; 8  } 9 10 public void setRegion(String region) { 11 this.region = region; 12  } 13 14 public Long getId() { 15 return id; 16  } 17 18 public void setId(Long id) { 19 this.id = id; 20  } 21 22 public Set<Song> getSongs() { 23 return songs; 24  } 25 26 public void setSongs(Set<Song> songs) { 27 this.songs = songs; 28  } 29 30 public void addSong(Song song){ 31  songs.add(song); 32 song.setSinger(this); 33  } 34 }

 

3.

 1 public class SingleSinger extends Singer {
 2     private String name;
 3     private char sex;
 4     
 5     public String getName() {
 6         return name;
 7  } 8 9 public void setName(String name) { 10 this.name = name; 11  } 12 13 public char getSex() { 14 return sex; 15  } 16 17 public void setSex(char sex) { 18 this.sex = sex; 19  } 20 }

 

3.

 1 package edu.jlu.fuliang.domain;
 2 
 3 import java.util.HashSet;
 4 import java.util.Set;
 5 
 6 public class CompositeSinger extends Singer {
 7     private Set<SingleSinger> singleSingers = new HashSet<SingleSinger>();
 8 
 9     public Set<SingleSinger> getSingleSingers() { 10 return singleSingers; 11  } 12 13 public void setSingleSingers(Set<SingleSinger> singleSingers) { 14 this.singleSingers = singleSingers; 15  } 16 public void addSinger(SingleSinger singleSinger){ 17  singleSingers.add(singleSinger); 18  } 19 }

 

5.

 1 public class Band extends CompositeSinger {
 2     private String name;
 3     
 4     public String getName() {
 5         return name;
 6     }
 7 
 8     public void setName(String name) { 9 this.name = name; 10  } 11 }

 

6.

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 3 "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
 4 
 5 <hibernate-mapping package="edu.jlu.fuliang.domain">
 6     <class name="Singer" table="SINGER">
 7       <id name="id" type="java.lang.Long">
 8          <column name="SINGER_ID"/>
 9          <generator class="identity"/>
10       </id>
11       
12      <discriminator column="TYPE" type="string"/>
13      
14      <property name="region" type="java.lang.String">
15          <column name="REGION"/>
16      </property> 
17       
18       <set name="songs" table="SONG" inverse="true" cascade="save-update">
19          <key column="SINGER_ID"/>
20          <one-to-many class="Song"/> 
21       </set>
22       
23       <subclass name="SingleSinger" discriminator-value="1">
24          <property name="name" type="java.lang.String">
25               <column name="NAME"/>
26          </property>
27          <property name="sex" type="java.lang.Character">
28              <column name="SEX"/>
29          </property>
30       </subclass>
31       
32       <subclass name="CompositeSinger" discriminator-value="2">
33          <set name="singleSingers" table="SINGER" cascade="save-update" lazy="false">
34              <key column="COMPSITESINGER_ID"/>
35              <one-to-many class="SingleSinger"/>
36          </set>
37       </subclass>
38       
39       <subclass name="Band" discriminator-value="3">
40           <set name="singleSingers" table="SINGER" cascade="save-update">
41              <key column="BAND_ID"/>
42              <one-to-many class="SingleSinger"/>
43          </set>
44       </subclass>
45     </class>
46 </hibernate-mapping>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值