Hibernate學習10(映射一對一關聯(外鍵))

如部門經理對應一個部門

基于外鍵的一對一關聯關系

  • 1.外鍵可以存放在任意一邊,在需要存放外鍵的一端增加many-to-one元素 并為其添加唯一約束unique="true"

  • 2.另一端需要使用one-to-one元素,并使用property-ref屬性指定被關聯實體主鍵以外字段作為關聯字段

通過外鍵方式映射一對一關聯

對象一(部門)
//部門
public class Department {
    private Integer depId;
    private String depName;
    private Manager mgr;

    public Manager getMgr() {
        return mgr;
    }

    public void setMgr(Manager mgr) {
        this.mgr = mgr;
    }

    public Integer getDepId() {
        return depId;
    }

    public void setDepId(Integer depId) {
        this.depId = depId;
    }

    public String getDepName() {
        return depName;
    }

    public void setDepName(String depName) {
        this.depName = depName;
    }

}
對象二(部門經理)
//經理
public class Manager {

    private Integer mId;
    private String mName;
    private Department dep;
    public Integer getmId() {
        return mId;
    }
    public void setmId(Integer mId) {
        this.mId = mId;
    }
    public String getmName() {
        return mName;
    }
    public void setmName(String mName) {
        this.mName = mName;
    }
    public Department getDep() {
        return dep;
    }
    public void setDep(Department dep) {
        this.dep = dep;
    }
    
}
對象一(部門)映射文件: 建立一對多關系 為外鍵添加唯一約束
  • 使用many-to-one 映射一對一關聯更新 unique="true"唯一約束
<hibernate-mapping>
    <class name="chen.Department" table="DEPARTMENT">
        <id name="depId" type="java.lang.Integer">
            <column name="DEPID" />
            <generator class="native" />
        </id>
        <property name="depName" type="java.lang.String">
            <column name="DEPNAME" />
        </property>
        <!-- 使用many-to-one 映射一對一關聯更新
        unique="true"唯一約束
         -->
        <many-to-one name="mgr" class="chen.Manager" column="MGR_ID" unique="true"> </many-to-one>
    </class>
</hibernate-mapping>
部門數據表
對象二(經理)映射文件: 建立一對一關聯
  • 使用 one-to-one映射一對一關聯關系
  • 默認關聯對方OID
  • property-ref="mgr"指定使用關聯實體主鍵以外的字段關聯 (對象屬性名)
<hibernate-mapping>
    <class name="chen.Manager" table="MANAGER">
        <id name="mId" type="java.lang.Integer" access="field">
            <column name="MID" />
            <generator class="native" />
        </id>
        <property name="mName" type="java.lang.String" access="field">
            <column name="MNAME" />
        </property>
        <!-- 使用 one-to-one映射一對一關聯關系 -->
        <!-- property-ref="mgr"指定使用關聯實體主鍵以外的字段關聯 (對象屬性名) -->
        <one-to-one name="dep" class="chen.Department"
            property-ref="mgr"></one-to-one>
    </class>
</hibernate-mapping>

經理數據表
保存
  • 建議先保存沒有外鍵列 減少update語句
    /**
     * 一對一關聯(外鍵) 保存
     */
    public static void testOneToOneWSave() {
        StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();// 配置文件configure()
        SessionFactory sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
        Session session = sessionFactory.openSession();
        Transaction transaction = session.beginTransaction();

        Department department = new Department();
        department.setDepName("研發部");

        Manager manager = new Manager();
        manager.setmName("張三");

        // 設置關聯
        department.setMgr(manager);
        manager.setDep(department);

        // 建議先保存沒有外鍵列 減少update語句
        session.save(manager);
        session.save(department);

        transaction.commit();
        session.close();
        sessionFactory.close();
    }
查詢
  • 1.默認對關聯屬性使用懶加載
  • 2.會出現懶加載異常
  • 3.查詢manager 對象鏈接條件不對 property-ref="mgr"指定使用關聯實體主鍵以外的字段關聯
    /**
     * 一對一關聯(外鍵) 查詢
     */
    public static void testOneToOneWGetA() {
        StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();// 配置文件configure()
        SessionFactory sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
        Session session = sessionFactory.openSession();
        Transaction transaction = session.beginTransaction();

        // 1.默認對關聯屬性使用懶加載
        // 2.會出現懶加載異常
        Department department = session.get(Department.class, 1);
        System.out.println(department.getDepName());

        // 3.查詢manager 對象鏈接條件不對
        Manager manager = department.getMgr();
        System.out.println(manager.getmName());

        transaction.commit();
        session.close();
        sessionFactory.close();
    }
  • 在查詢沒有外鍵的實體對象,使用的左外鏈接查詢,一并查詢出其關聯對象
    /**
     * 一對一關聯(外鍵) 查詢
     */
    public static void testOneToOneWGetB() {
        StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();// 配置文件configure()
        SessionFactory sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
        Session session = sessionFactory.openSession();
        Transaction transaction = session.beginTransaction();

        Manager manager = session.get(Manager.class, 1);
        System.out.println(manager.getmName());
        // 在查詢沒有外鍵的實體對象,使用的左外鏈接查詢,一并查詢出其關聯對象
        System.out.println(manager.getDep().getDepName());

        transaction.commit();
        session.close();
        sessionFactory.close();
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,673評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,610評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,668評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,004評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,173評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,705評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,426評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,656評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,833評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,371評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,621評論 2 380

推薦閱讀更多精彩內容

  • 再開始本次知識點之前,我們先來思考下get與load的區別。 對于Hibernate get方法,Hibernat...
    FTOLsXD閱讀 361評論 0 1
  • 上篇文章我們對持久化對象進行的學習,了解了它的三種不同的狀態并通過它完成對數據庫的映射操作。但這都是基于單張表的操...
    Single_YAM閱讀 511評論 0 1
  • 1. 簡介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存儲過程以及高級映射的優秀的...
    笨鳥慢飛閱讀 5,571評論 0 4
  • 基于主鍵一對一 1.一端主鍵生成器使用foreign策略,表明根據對方主鍵來生成自己的主鍵,自己不獨立生成主鍵, ...
    又是那一片天閱讀 327評論 0 0
  • 記不清有多久沒有再見到過胡楊了,不過這樣也好,永遠都會是記憶中最好的樣子。當我用眼淚和汗水描寫人生的時候,...
    趙瓷錘閱讀 257評論 0 0