溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

java中Hibernate的狀態(tài)有哪些

發(fā)布時(shí)間:2021-01-25 15:49:48 來源:億速云 閱讀:121 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)java中Hibernate的狀態(tài)有哪些,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

1.瞬時(shí)狀態(tài)

通過new開辟內(nèi)存空間創(chuàng)建的實(shí)體對(duì)象,但是它沒有納入hibernate session的管理之中,如果沒有變量對(duì)它引用,它將會(huì)被JVM(垃圾回收器)回收。瞬時(shí)狀態(tài)的對(duì)象在內(nèi)存中是孤立的,它與數(shù)據(jù)庫無任何關(guān)聯(lián),僅僅是一個(gè)信息攜帶的載體。

一個(gè)瞬時(shí)狀態(tài)對(duì)象被持久化狀態(tài)對(duì)象引用,它也會(huì)自動(dòng)變?yōu)槌志没癄顟B(tài)對(duì)象。例如調(diào)用session的save、saveorupdate等方法的時(shí)候。

特征:

(1)使用 new 創(chuàng)建出來的對(duì)象,沒有設(shè)置 id 屬性

(2)沒有被 session 托管,換句話說 對(duì)象數(shù)據(jù) 存放在內(nèi)存中, 沒有存放到 session 緩存中

(3)臨時(shí)對(duì)象數(shù)據(jù) 與 數(shù)據(jù)庫中的數(shù)據(jù) 還沒任何關(guān)聯(lián)

2.持久化狀態(tài)

持久化狀態(tài)對(duì)象存在與數(shù)據(jù)庫中的數(shù)據(jù)關(guān)聯(lián),它總是與會(huì)話狀態(tài)(Session)和事務(wù)(Transaction)關(guān)聯(lián)在一起。當(dāng)持久化狀態(tài)對(duì)象發(fā)生變動(dòng)時(shí)并不會(huì)立即執(zhí)行數(shù)據(jù)庫操作,只有當(dāng)事務(wù)結(jié)束時(shí),才會(huì)更新數(shù)據(jù)庫,以便保證Hibernate的持久化對(duì)象和數(shù)據(jù)庫操作的同步性。

當(dāng)持久化狀態(tài)對(duì)象變?yōu)橥泄軤顟B(tài)對(duì)象時(shí),它將不在Hibernate持久層的管理范圍之內(nèi)。

特征:

(1)要么是從數(shù)據(jù)庫中使用 get 或 load 方法查詢到的數(shù)據(jù)對(duì)象, 要么是 使用save 或 update 方法數(shù)據(jù)轉(zhuǎn)變成持久層對(duì)象

(2)對(duì)象 數(shù)據(jù)被 session 托管。換句話說 對(duì)象數(shù)據(jù) 在 session 緩存中有一份,在數(shù)據(jù)庫中有相應(yīng)的記錄

3.脫管狀態(tài)

當(dāng)持久化對(duì)象的Session關(guān)閉之后,這個(gè)對(duì)象就從持久化狀態(tài)變?yōu)橥泄軤顟B(tài)。托管狀態(tài)的對(duì)象仍然在與數(shù)據(jù)庫中的數(shù)據(jù)關(guān)聯(lián),但是他并不在Hibernate的Session管轄范圍之內(nèi)。

如果將脫管狀態(tài)的對(duì)象重新關(guān)聯(lián)到某個(gè)新的Session上,它將變回持久化狀態(tài)對(duì)象。

特征:

(1)主要是通過 持久狀態(tài)對(duì)象,調(diào)用 session.evict() 或 session.clear() 或 session.close() 得到的,也可以new 一個(gè)設(shè)置 id 值的對(duì)象

(2)session 緩存中沒有,內(nèi)存中有的對(duì)象(注: 該對(duì)象設(shè)置了 id 值)

4.刪除態(tài)

調(diào)用session的delete方法時(shí),對(duì)象轉(zhuǎn)為刪除態(tài)。刪除態(tài)只能等待被回收。

知識(shí)點(diǎn)擴(kuò)展:

Hibernate的檢索方式

導(dǎo)航對(duì)象圖檢索(根據(jù)已經(jīng)加載的對(duì)象,導(dǎo)航到其他對(duì)象。)

  •  OID檢索(按照對(duì)象的OID來檢索對(duì)象。)

  •  HQL檢索(使用面向?qū)ο蟮腍QL查詢語言。)

  •  QBC檢索(使用QBC(Qurey By Criteria)API來檢索對(duì)象。 QBC/QBE離線/在線)

  •  本地SQL檢索(使用本地?cái)?shù)據(jù)庫的SQL查詢語句。)

包括Hibernate的檢索方式,Hibernate中對(duì)象的狀態(tài),Hibernate的3種檢索策略是什么,分別適用于哪種場合,ORM解決的不匹配問題, Hibernate映射繼承關(guān)系的3種方式,Session的find()方法以及Query接口的區(qū)別等方面問題的總結(jié)

臨時(shí)狀態(tài)(transient):剛剛用new語句創(chuàng)建,還沒有被持久化,不處于Session的緩存中。處于臨時(shí)狀態(tài)的Java對(duì)象被稱為臨時(shí)對(duì)象。

持久化狀態(tài)(persistent):已經(jīng)被持久化,加入到Session的緩存中。處于持久化狀態(tài)的Java對(duì)象被稱為持久化對(duì)象。

游離狀態(tài)(detached):已經(jīng)被持久化,但不再處于Session的緩存中。處于游離狀態(tài)的Java對(duì)象被稱為游離對(duì)象。

Hibernate的3種檢索策略是什么,分別適用于哪種場合

立即檢索

優(yōu)點(diǎn):對(duì)應(yīng)用程序完全透明。

缺點(diǎn):select語句數(shù)目多。

適用:類級(jí)別。

延遲檢索

優(yōu)點(diǎn):由應(yīng)用程序決定加載哪些對(duì)象,可以避免執(zhí)行多余的select語句以及避免加載不需要訪問的對(duì)象,節(jié)省內(nèi)存空間,提高檢索效率。

缺點(diǎn):應(yīng)用程序如果要訪問游離態(tài)的代理類實(shí)例,必須保證它在持久化時(shí)已經(jīng)被初始化。

適用:一對(duì)多或多對(duì)多關(guān)聯(lián)。應(yīng)用程序不需要立即訪問或者根本不會(huì)訪問的對(duì)象。

迫切左外連接檢索

優(yōu)點(diǎn):對(duì)應(yīng)用程序完全透明,不管對(duì)象處于持久化狀態(tài)還是游離狀態(tài),應(yīng)用程序都可以方便的從一個(gè)對(duì)象導(dǎo)航到另一個(gè)與它相關(guān)聯(lián)的對(duì)象。使用了外連接,select語句數(shù)目少。

缺點(diǎn):可能會(huì)加載程序不許要訪問的對(duì)象。復(fù)雜的數(shù)據(jù)庫表連接形象檢索性能。

適用:一對(duì)一或多對(duì)一關(guān)聯(lián)。應(yīng)用程序需要立即訪問的對(duì)象。數(shù)據(jù)庫系統(tǒng)具有良好的表連接性能。

看完上述內(nèi)容,你們對(duì)java中Hibernate的狀態(tài)有哪些有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI