分析Hibernate映像文件
本文向大家介紹Hibernate映像文件實(shí)例,可能好多人還不了解Hibernate映像文件,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。
Hibernate映像文件實(shí)例
們已經(jīng)從改用這樣的純凈的對(duì)象id中獲取了不少好處。我們對(duì)equals()和hashCode()方法的實(shí)現(xiàn)更加簡(jiǎn)單而且容易閱讀。這些方法再也不易出錯(cuò)而且無論在保存對(duì)象之前還是之后,它們都能和Collection一起正常工作。Hibernate也能夠變的更快一些,這是因?yàn)樵诒4嫘碌膶?duì)象之前它再也不需要從數(shù)據(jù)庫(kù)讀取一個(gè)序列值。此外,新定義的equals()和hashCode()對(duì)于一個(gè)包含 id對(duì)象的對(duì)象來說是具有通用性的。這意味著我們可以把這些方法移動(dòng)到一個(gè)抽象的父類當(dāng)中去。我們不再需要為每一個(gè)域?qū)ο笾匦聦?shí)現(xiàn)equals()和 hashCode(),而且我們也不再需要考慮對(duì)于一個(gè)類來說哪些字段的組合是***且不變的。我們只要簡(jiǎn)單地繼承這個(gè)抽象類。當(dāng)然,我們沒必要強(qiáng)迫我們的域?qū)ο罄^承一個(gè)父類,所以我們定義了一個(gè)接口來保證設(shè)計(jì)的靈活性。
- public interface PersistentObject {
- public String getId();
- public void setId(String id);
- public Integer getVersion();
- public void setVersion(Integer version);
- }
- public abstract class AbstractPersistentObject implements PersistentObject {
- private String id = IdGenerator.createId();
- private Integer version;
- public String getId() { return id;
- }
- public void setId(String id) { this.id = id; }
- public Integer getVersion() { return version; }
- public void setVersion(Integer version) { this.version = version; }
- public boolean equals(Object o) {
- if (this == o) return true;
- if (o == null || !(o instanceof PersistentObject)) { return false; }
- PersistentObject other = (PersistentObject)o;
- // if the id is missing,
- return false
- if (id == null) return false;
- // equivalence by id
- return id.equals(other.getId());
- }
- public int hashCode() {
- if (id != null) {
- return id.hashCode();
- } else {
- return super.hashCode();
- }
- }
- public String toString() {
- return this.getClass().getName() + "[id=" + id + "]";
- }
- }
現(xiàn)在我們有了一個(gè)簡(jiǎn)單而高效的方法來創(chuàng)建域?qū)ο?。它們繼承了AbstractPersistentObject,這個(gè)父類能在它們***次被創(chuàng)建時(shí)自動(dòng)賦予它們一個(gè)id并且恰當(dāng)?shù)膶?shí)現(xiàn)了equals()和hashCode()這兩個(gè)方法。域?qū)ο笠驳玫搅艘粋€(gè)對(duì)toString()方法的合理的缺省實(shí)現(xiàn),這個(gè)方法可以有選擇地被重寫。如果這是一個(gè)查詢例子的測(cè)試對(duì)象或者例子對(duì)象,id值時(shí)可以被改變或者被設(shè)為null。否則它是不應(yīng)當(dāng)被改變的。如果因?yàn)槟承┰蛭覀冃枰獎(jiǎng)?chuàng)建一個(gè)繼承自其它類的域?qū)ο?,這個(gè)對(duì)象就應(yīng)當(dāng)實(shí)現(xiàn)PersistentObject接口而不是繼承抽象類。
- public class Person extends AbstractPersistentObject {
- // Person-specific fields and behavior here
- }
從上一個(gè)例子開始Hibernate映像文件就不會(huì)再改變了。我們不想麻煩Hibernate去了解抽象父類,相對(duì)的,我們只要保證每個(gè)持久化對(duì)象的映射文件包含一個(gè)id項(xiàng)(和一個(gè)被指派的生成器)和一個(gè)帶有unsaved- value="null"屬性的version標(biāo)簽。機(jī)敏的讀者可能已經(jīng)注意到,每當(dāng)一個(gè)持久化對(duì)象被實(shí)例化的時(shí)候,它的id值得到了指派。這意味著當(dāng)Hibernate在內(nèi)存中創(chuàng)建一個(gè)已經(jīng)保存過的對(duì)象時(shí),雖然這個(gè)對(duì)象是已經(jīng)存在并從數(shù)據(jù)庫(kù)中讀取的,它也會(huì)得到一個(gè)新的id。這不會(huì)產(chǎn)生問題,因?yàn)镠ibernate會(huì)接著調(diào)用對(duì)象的setId()方法,用保存的真實(shí)id來替換新分配的id。剩下的id生成器并不是問題,因?yàn)閷?shí)現(xiàn)它的算法是輕量級(jí)的(也就是說,它并不牽扯到數(shù)據(jù)庫(kù))。
到現(xiàn)在為止一切都很好,但是我們遺漏了一個(gè)重要的細(xì)節(jié):如何實(shí)現(xiàn)IdGenerator.createId().我們可以為我們理想中的鍵值生成器(key-generation)算法定義一些標(biāo)準(zhǔn)。
◆鍵值可以不牽扯到數(shù)據(jù)庫(kù)而很輕量級(jí)的產(chǎn)生
◆即使跨越不同的虛擬機(jī)和不同機(jī)器,鍵值也要保證***性。
◆如果可能鍵值可以由其它程序,編程語(yǔ)言和數(shù)據(jù)庫(kù)生成,至少要能和它們兼容
【編輯推薦】