Hibernate繼承映射的第1種策略:每棵類繼承樹對應一張表(所有子類信息都存在一張表裏,用一個字段來區分)
1、理解如何映射
因爲類繼承樹肯定是對應多個類,要把多個類的信息存放在一張表中,必須有
某種機制來區分哪些記錄是屬於哪個類的。
這種機制就是,在表中添加一個字段,用這個字段的值來進行區分。用hibernate實現這種策略的時候,有如下步驟:
父類用普通的<class>標籤定義
在父類中定義一個discriminator,即指定這個區分的字段的名稱和類型
如:<discriminator column=”XXX” type=”string”/>
子類使用<subclass>標籤定義,在定義subclass的時候,需要注意如下幾點:
Subclass標籤的name屬性是子類的全路徑名
在Subclass標籤中,用discriminator-value屬性來標明本子類的discriminator字段(用來區分不同類的字段)的值
Subclass標籤,既可以被class標籤所包含(這種包含關係正是表明了類之間的繼承關係),也可以與class標籤平行。
當subclass標籤的定義與class標籤平行的時候,需要在subclass標籤中,添加extends屬性,裏面的值是父類的全路徑名稱。
子類的其它屬性,像普通類一樣,定義在subclass標籤的內部。
2、理解如何存儲
在存儲數據的時候,hibernate會自動將鑑別字段的值插入到數據庫中,在加載數據的時候,
hibernate便能根據這個鑑別字段正確的加載對象
3、理解何爲多態查詢,即hibernate能夠加載數據的時候自動鑑別其真正的類型
多態get(),支持
多態load(),設置Lazy=“false”時,支持
多態查詢,支持
Hibernate繼承映射的第2種策略:每個類對應一張表(父類存放公共信息、子類存放特有信息)
1、如何映射
這種策略是使用joined-subclass標籤來定義子類的。父類、子類,每個類都對應一張數據庫表。
在父類對應的數據庫表中,實際上會存儲所有的記錄,包括父類和子類的記錄;在子類對應的數據庫表中,
這個表只定義了子類中所特有的屬性映射的字段。子類與父類,通過相同的主鍵值來關聯。實現這種策略的時候,有如下步驟:
父類用普通的<class>標籤定義即可
父類不再需要定義discriminator字段
子類用<joined-subclass>標籤定義,在定義joined-subclass的時候,需要注意如下幾點:
Joined-subclass標籤的name屬性是子類的全路徑名
Joined-subclass標籤需要包含一個key標籤,這個標籤指定了子類和父類之間是通過哪個字段來關聯的。
如:<key column=”PARENT_KEY_ID”/>,這裏的column,實際上就是父類的主鍵對應的映射字段名稱。
Joined-subclass標籤,既可以被class標籤所包含(這種包含關係正是表明了類之間的繼承關係),
也可以與class標籤平行。 當Joined-subclass標籤的定義與class標籤平行的時候,需要在Joined-subclass標籤中,添加extends屬性,裏面的值是父類的全路徑名稱。
子類的其它屬性,像普通類一樣,定義在joined-subclass標籤的內部。
2、存儲和多態查詢參見策略一:每棵類繼承樹對應一張表
Hibernate繼承映射的第3種策略:每個具體類一張表(每個子類對應一張信息完備的表)
1、如何映射
這種策略是使用union-subclass標籤來定義子類的。每個子類對應一張表,而且這個表的信息是完備的,
即包含了所有從父類繼承下來的屬性映射的字段(這就是它跟joined-subclass的不同之處,joined-subclass定義的子類的表,
只包含子類特有屬性映射的字段)。實現這種策略的時候,有如下步驟:
父類用普通<class>標籤定義即可
子類用<union-subclass>標籤定義,在定義union-subclass的時候,需要注意如下幾點:
Union-subclass標籤不再需要包含key標籤(與joined-subclass不同)
Union-subclass標籤,既可以被class標籤所包含(這種包含關係正是表明了類之間的繼承關係),
也可以與class標籤平行。 當Union-subclass標籤的定義與class標籤平行的時候,需要在Union-subclass標籤中,添加extends屬性,裏面的值是父類的全路徑名稱。
子類的其它屬性,像普通類一樣,定義在Union-subclass標籤的內部。這個時候,雖然在union-subclass裏面定義的只有子類的屬性,但是因爲它繼承了父類,所以,
不需要定義其它的屬性,在映射到數據庫表的時候,依然包含了父類的所有屬性的映射字段。
!!!特別注意:在保存對象的時候,id不能重複(所以不能用自增方法生成主鍵)
2、存儲和多態查詢參見策略一:每棵類繼承樹對應一張表
Hibernate繼承映射的第4種策略:每個子類一張表,使用辨別標誌(Discriminator)(超類表+每個子類對應一張信息完備的表)
官方文檔解釋:該方法要求在超類 表中有一個類型辨別字段(type discriminator column),從關係(數據庫)的角度來看,按理說它更正確,可以結合使用<subclass>
與<join>,...。
傳智播客老師解釋:對於屬性較少的子類直接和父類一個表,對於屬性較多子類,共同屬性與父類同表,獨有屬性單獨一張表。這是父類表就要使用辨別標誌區分各類了。