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>

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM