一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 淺析Java的Hibernate框架中的繼承關系設計

淺析Java的Hibernate框架中的繼承關系設計

2020-03-14 15:25cxshun JAVA教程

這篇文章主要介紹了Java的Hibernate框架中的繼承關系設計,Hibernate是Java的SSH三大web開發框架之一,需要的朋友可以參考下

這次我們來說一下hibernate的層次設計,層次設計也就是實體之間的繼承關系的設計。
 也許這樣比較抽象,我們直接看例子。
 1)我們先看一下普通的做法
 直接上代碼:三個實類如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class TItem implements Serializable{
    //省略Get/Set方法
  private int id;
  private String manufacture;
  private String name;  
}
public class TBook extends TItem{
    //省略Get/Set方法
  private int pageCount;
   
}
public class TDVD extends TItem{
    //省略Get/Set方法
  private String regionCode;
}

 
  這里我們需要三個映射文件,內容如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<class name="TItem" table="ITEM">
    <id name="id" column="id" type="java.lang.Integer">
      <generator class="native" />
    </id>
    <property name="name" column="name" type="java.lang.String"/>
    <property name="manufacture" column="manufacture" type="java.lang.String"/>
  </class>
<class name="TBook" table="Book">
    <id name="id" column="id" type="java.lang.Integer">
      <generator class="native" />
    </id>
    <property name="name" column="name" type="java.lang.String"/>
    <property name="manufacture" column="manufacture" type="java.lang.String"/>
    <property name="pageCount" column="pageCount" type="java.lang.Integer"/>
  </class>
<class name="TDVD" table="DVD">
    <id name="id" column="id" type="java.lang.Integer">
      <generator class="native" />
    </id>
    <property name="name" column="name" type="java.lang.String"/>
    <property name="manufacture" column="manufacture" type="java.lang.String"/>
    <property name="regionCode" column="regionCode" type="java.lang.String"/>
  </class>

  很普通的映射文件,跟以前的沒什么區別。
 下面我們直接寫一個測試方法:

?
1
2
3
4
5
6
7
8
9
10
11
public void testSelect() {
     
    Query query = session.createQuery("from TItem ");
    List list = query.list();
    Iterator iter = list.iterator();
     
    while(iter.hasNext()) {
      System.out.println("Name:"+(((TItem)iter.next()).getName()));
    }
     
  }

  注意,這里我們是用TItem類,而不是具體的字類,這里它會自動去查找繼承于TItem類的子類,查出所有結果。這里涉及到一個多態模式,class標簽有屬性 polymorphism,它的默認值為implicit,這意味著不需要指定名稱就可以查詢出結果。如果為explicit則表明需要指定具體的類名時,才可以查出此類的結果。
 2)上個例子中我們用到了三個映射文件,當我們需要修改時,就需要修改三個映射文件,這對于大的項目是很不可行的。而且每個表都有對應的主類的對應字段,這是多余的。所以我們有下面這種方法。
 實體類還是跟1)中的一樣。我們把映射文件由三個改為一個,只保留TItem映射文件。但我們需要做相應的修改,現在內容如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<class name="TItem" table="ITEM" polymorphism="explicit">
    <id name="id" column="id" type="java.lang.Integer">
      <generator class="native" />
    </id>
    <property name="name" column="name" type="java.lang.String"/>
    <property name="manufacture" column="manufacture" type="java.lang.String"/>
    <joined-subclass name="TBook" table="TBOOK">
      <key column="id" />
      <property name="pageCount" column="pageCount" type="java.lang.Integer" />
    </joined-subclass>
    <joined-subclass name="TDVD" table="TDVD">
      <key column="id"/>
      <property name="regionCode" column="regionCode" type="java.lang.String"/> 
    </joined-subclass>
  </class>

 
  這里,我們只有一個映射文件,但有一個joined-subclass標簽,它表明這個類繼承于當前類,<key>表明分表的主鍵,這里分表是指TBOOK和TDVD這兩個由子類對應的表。分表中只有字段在property中指定。
 這樣當我們運行后生成的表就如下圖:

淺析Java的Hibernate框架中的繼承關系設計

兩個子類對應的表只有我們通過property指定的字段。這樣就避免了表內有多個字段,使字表只維護其單獨字段,當item類進行改變時,也不用過多的進行修改。

3)再來了解另外一種方法實現層次設計,這就是通過在表內置入標志來實現。在hibernate的映射文件中我們通過descriminator標簽來進行實現。
 廢話不多說,我們直接看例子:
 我們把昨天的TItem的映射文件修改為:

?
1
2
3
4
5
6
7
8
9
<class name="TItem" table="ITEM" polymorphism="explicit">
    <id name="id" column="id" type="java.lang.Integer">
      <generator class="native" />
    </id>
     <discriminator column="category" type="java.lang.String"/>
      
     <property name="name" column="name" type="java.lang.String"/>
     <property name="manufacture" column="manufacture" type="java.lang.String"/>    
  </class>

  看到中間,我們加入了一個discriminator標簽,它表明我們以下的兩個subclass通過哪個字段來進行區別。

?
1
2
3
4
5
6
<subclass name="TBook" discriminator-value="1">
    <property name="pageCount" column="pageCount"/>
   </subclass>
   <subclass name="TDVD" discriminator-value="2" >
    <property name="regionCode" column="regionCode"/>
   </subclass>

  我們看到這兩段,它指明了當discriminator所指定的field的值為1時,表明它是TBook類,并且pageCount有值;當discriminator所指定的field值為2時,表明它是TDVD類,并且regionCode有值。
 這樣我們就只需要用到一個表,就表明了它們幾個類的關系了,注意,這種方式對有過多子類的情況下,并不好,它會使主表的字段過多,會造成一定的設計上的不便。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 51国产午夜精品免费视频 | 国产自一区 | 日本不卡免费新一二三区 | 天堂素人在线 | 久久人妻熟女中文字幕AV蜜芽 | 娇妻在床上迎合男人 | 欧美xxxxx性| 动漫美女被吸乳羞羞小说 | 免费人成网址在线观看国内 | 亚洲国产99在线精品一区二区 | 久久精品热只有精品 | 亚州一区二区 | 99久久综合给久久精品 | 久久久久久免费观看 | 日韩亚洲人成在线综合 | 毛片的网站 | 国产首页精品 | 日本一区二区三区在线 观看网站 | 亚洲AV无码A片在线观看蜜桃 | 99久久精品免费看国产 | 美日韩一区二区三区 | 亚洲 欧美 中文字幕 在线 | 18亚洲chinese男男1069 | 亚洲欧洲日产v特级毛片 | 草留色区| 婷婷综合亚洲 | 亚洲成人贴图 | 性伴交换多p | 久久国产热视频99rev6 | 日韩国产成人精品视频 | 秋霞理论最新三级理论最 | 欧美一级欧美一级高清 | 色中文| 四虎地址8848aa4hc44四虎 四虎成人永久地址 | 日韩亚洲一区中文字幕在线 | 白丝超短裙被输出娇喘不停小说 | 舔比小说| 精品精品国产自在现拍 | 亚洲国产一区二区三区a毛片 | 国产欧美日韩不卡一区二区三区 | 91在线免费看 |