hibernate多對多的更進一步的應用

2021-09-01 23:55:35 字數 951 閱讀 7683

回顧:

一對多的自關聯

選單:單錶中的資料有層次關係的時候,咱們使用自關聯

many-to-one

set多對多查詢

書籍與類別的關係

級聯查詢

查詢id對應的書籍資訊,可以關聯查詢出類別

查詢id對應的類別,可以關聯查詢出書籍

資料庫的多對多

1.1 資料庫中不能直接對映多對多

處理:建立乙個橋接表(中間表),將乙個多對多關係轉換成兩個一對多

注1:資料庫多表聯接查詢

永遠就是二個表的聯接查詢

a   b   c  d

t1 c

t2 d

t3

注2:交叉連線

注3:外連線:left(左)/right(右)/full(左右)

主從表:連線條件不成立時,主表記錄永遠保留,與null匹配

a	b	ab

select * from a,b,ab where a.aid=ab.aid and b.bid = ab.bid

where

在hibernate中,你只管查詢當前表物件即可,

hibernate會欄位關聯橋表以及關聯表查詢出關聯物件

hibernate的多對多

2.1 hibernate可以直接對映多對多關聯關係(看作兩個一對多)

多對多關係注意事項

3.1 一定要定義乙個主控方

3.2 多對多刪除

3.2.1 主控方直接刪除

3.2.2 被控方先通過主控方解除多對多關係,再刪除被控方

3.2.3 禁用級聯刪除

3.3 關聯關係編輯,不需要直接操作橋接表,hibernate的主控方會自動維護

案例:級聯新增 inverse屬性值的設定

級聯刪除

hibernate的多對多

近日工作中遇到多對多,以前未曾用過hibernate,這次也算是摸著石頭過河。之前試驗了級聯的cascadetype.all,卻發現當刪除部門表的時候,中間表資料刪除了,結果將人員表相關聯的資料也全部刪除了。後來將級聯改為cascadetype.persist,cascadetype.merge,倒...

hibernate的多對多

1.herbernate一對多自關聯 樹形選單查詢可能出現的問題 當載入一級節點的時候沒問題 強制載入 載入二級載入時候,由於設定了強制載入,同樣可以載入出所有的二級節點。沒問題 載入 節點時,這是session關閉了,並且預設採用的是懶載入 許可權選單載入有兩種方式 1 一次性將資料庫表中的資料全...

hibernate的多對多

多對多關聯是hibernate中一種比較特殊的關聯,它需要借助中間表來完成多對多資訊的儲存。多對多關聯只有雙向關聯。資料庫的多對多 資料庫中不能直接對映多對多 處理 建立乙個橋接表 中間表 將乙個多對多關係轉換成兩個一對多。hibernate的多對多 hibernate可以直接對映多對多關聯關係 看...