三種狀態(tài)
Transient(臨時(shí)狀態(tài)):new出來的對(duì)象;它沒有持久化共屈,不存在于Session中——此狀態(tài)中的對(duì)象為臨時(shí)對(duì)象绑谣。
Persistent(持久化狀態(tài)):已經(jīng)持久化,存在于Session緩存中拗引;如經(jīng)hibernate語句save()保存的對(duì)象——此狀態(tài)對(duì)象為持久對(duì)象借宵。
Detached(游離狀態(tài)):持久化對(duì)象脫離了Session后的對(duì)象。如Session緩存被清空后的對(duì)象矾削。已經(jīng)持久化壤玫,單不存在于Session中——此狀態(tài)中的對(duì)象為游離對(duì)象豁护。
三種狀態(tài)的區(qū)分:
(1)對(duì)象有沒有Id——如果沒有Id,一定是Transient狀態(tài)
(2)Id在數(shù)據(jù)庫中有沒有
(3)在內(nèi)存中有沒有(session緩存)
Transient: new出來一個(gè)對(duì)象欲间,緩存和數(shù)據(jù)庫都沒有id楚里;
Persistent:內(nèi)存、緩存猎贴、數(shù)據(jù)庫都有id;
Detached:內(nèi)存班缎、數(shù)據(jù)庫有id,緩存沒有
三種狀態(tài)與SQL語句:
如果一個(gè)對(duì)象已經(jīng)是持久化狀態(tài)了嘱能,那么此時(shí)對(duì)該對(duì)象進(jìn)行各種修改吝梅,或者調(diào)用多次update、save方法時(shí)惹骂,hibernate都不會(huì)發(fā)送sql語句苏携,只有當(dāng)事務(wù)提交的時(shí)候,此時(shí)hibernate才會(huì)拿當(dāng)前這個(gè)對(duì)象與之前保存在session中的持久化對(duì)象進(jìn)行比較对粪,如果不相同就發(fā)送一條update的sql語句右冻,否則就不會(huì)發(fā)送update語句
持久化對(duì)象在進(jìn)行修改之后,調(diào)用session.clear()方法著拭,這個(gè)時(shí)候就會(huì)將session的緩存對(duì)象清空纱扭,那么session中就沒有了這個(gè)對(duì)象,這個(gè)時(shí)候在提交事務(wù)的時(shí)候儡遮,發(fā)現(xiàn)已經(jīng)session中已經(jīng)沒有該對(duì)象了乳蛾,所以就不會(huì)進(jìn)行任何操作
Session的方法
save方法:
1.系統(tǒng)根據(jù)指定的ID生成策略,為臨時(shí)對(duì)象生成一個(gè)唯一的OID鄙币;
2.將臨時(shí)對(duì)象加載到緩存中肃叶,使之變成持久化對(duì)象;
3.提交事務(wù)時(shí)十嘿,清理緩存因惭,利用持久化對(duì)象包含的信息生成insert語句,將持久化對(duì)象保存到數(shù)據(jù)庫绩衷。
update方法:
1.用來更新detached對(duì)象蹦魔,更新完成后轉(zhuǎn)為persistent狀態(tài)。
2.更新自己設(shè)定的唯一標(biāo)識(shí)符(例如:Id)的transient對(duì)象且數(shù)據(jù)庫有對(duì)應(yīng)記錄的可以u(píng)pdate咳燕。
3.處于persistent狀態(tài)的對(duì)象勿决,對(duì)這個(gè)對(duì)象的屬性內(nèi)容進(jìn)行更改后當(dāng)commit時(shí)會(huì)自動(dòng)觸發(fā)Session update方法。
4.在XXX.hbm.xml文件中的設(shè)置dynamic-update=”true” 這樣就可以實(shí)現(xiàn)部分只進(jìn)行了更改字段的更新招盲。
delete方法:
刪除的時(shí)候是通過主鍵進(jìn)行刪除的,所以即使設(shè)置了不對(duì)應(yīng)的其它字段也是可以正常刪除數(shù)據(jù)的低缩。
get方法:
1.返回的對(duì)象是persistent持久化對(duì)象。
2.調(diào)用時(shí)發(fā)出查詢sql宪肖。
3.查不到返回null表制。
4.沒有延遲加載健爬。
5.get方法首先會(huì)查詢session緩存,沒有的話就查詢二級(jí)緩存么介,最后會(huì)查詢數(shù)據(jù)庫娜遵。
load方法:
1.返回的對(duì)象是persistent持久化對(duì)象。
2.調(diào)用延遲加載壤短,原理是用CGLIB生成代理類设拟,采用繼承,生成子類久脯。
3.真正使用對(duì)象的時(shí)候才發(fā)出查詢sql語句纳胧,先去二級(jí)緩存中查詢,如果沒有帘撰,再去數(shù)據(jù)庫中查詢跑慕。
4.如果查找不到會(huì)產(chǎn)生異常org.hibernate.ObjectNotFoundException。