淺談Hibernate outer-join參數(shù)
Hibernate有很多值得學(xué)習(xí)的地方,這里我們主要介紹Hibernate outer-join參數(shù),包括介紹many-to-one節(jié)點(diǎn)有以下屬性等方面。
set節(jié)點(diǎn)有以下屬性(摘自Hibernate文檔):
(1) name 集合屬性的名稱
(2) table(可選??默認(rèn)為屬性的名稱)這個集合表的名稱(不能在一對多的關(guān)聯(lián)關(guān)系中使用)
(3) schema (可選) 表的schema的名稱, 他將覆蓋在根元素中定義的schema
(4) lazy (可選??默認(rèn)為false) lazy(可選--默認(rèn)為false) 允許延遲加載(lazy initialization )(不能在數(shù)組中使用)
(5) inverse (可選??默認(rèn)為false) 標(biāo)記這個集合作為雙向關(guān)聯(lián)關(guān)系中的方向一端。
(6) cascade (可選??默認(rèn)為none) 讓操作級聯(lián)到子實(shí)體
(7) sort(可選)指定集合的排序順序, 其可以為自然的(natural)或者給定一個用來比較的類。
(8) order-by (可選, 僅用于jdk1.4) 指定表的字段(一個或幾個)再加上asc或者desc(可選), 定義Map,Set和Bag的迭代順序
(9) where (可選) 指定任意的SQL where條件, 該條件將在重新載入或者刪除這個集合時使用(當(dāng)集合中的數(shù)據(jù)僅僅是所有可用數(shù)據(jù)的一個子集時這個條件非常有用)
(10) Hibernate outer-join參數(shù)(可選)指定這個集合,只要可能,應(yīng)該通過外連接(outer join)取得。在每一個SQL語句中, 只能有一個集合可以被通過外連接抓取。
(11) batch-size (可選, 默認(rèn)為1) 指定通過延遲加載取得集合實(shí)例的批處理塊大小("batch size")。
(12) access(可選-默認(rèn)為屬性property):Hibernate取得屬性值時使用的策略。
many-to-one節(jié)點(diǎn)有以下屬性(摘自Hibernate文檔):
(1) name: 屬性名。
(2) column (可選): 字段名。
(3) class (可選 - 默認(rèn)是通過反射得到屬性類型): 關(guān)聯(lián)的類的名字。
(4) cascade(級聯(lián)) (可選): 指明哪些操作會從父對象級聯(lián)到關(guān)聯(lián)的對象。
(5) Hibernate outer-join參數(shù)(外連接) (可選 - 默認(rèn)為 自動): 當(dāng)設(shè)置hibernate.use_outer_join的時候,對這個關(guān)聯(lián)允許外連接抓取。
(6) update, insert (可選 - defaults to true) 指定對應(yīng)的字段是否在用于UPDATE 和/或 INSERT的SQL語句中包含。如果二者都是 false,則這是一個純粹的“外源性(derived)”關(guān)聯(lián),它的值是通過映射到同一個(或多個)字段的某些其他屬性得到的,或者通過 trigger(除法器),或者是其他程序。
(7) property-ref: (可選) 指定關(guān)聯(lián)類的一個屬性,這個屬性將會和本外鍵相對應(yīng)。如果沒有指定,會使用對方關(guān)聯(lián)類的主鍵。
(8) access(可選 - 默認(rèn)是 property): Hibernate用來訪問屬性的策略。
cascade屬性允許下列值: all, save-update, delete, none。設(shè)置除了none以外的其它值會傳播特定的操作到關(guān)聯(lián)的(子)對象中。參見后面的“Lifecycle Objects(自動管理生命周期的對象)”。
Hibernate outer-join參數(shù)允許下列三個不同值:
◆auto:(默認(rèn)) 使用外連接抓取關(guān)聯(lián)(對象),如果被關(guān)聯(lián)的對象沒有代理(proxy)
◆true:一直使用外連接來抓取關(guān)聯(lián)
◆false:永遠(yuǎn)不使用外連接來抓取關(guān)聯(lián)
【編輯推薦】