Posted on 2006-01-18 18:26
Asktalk 閱讀(3829)
評(píng)論(2) 編輯 收藏 所屬分類(lèi):
Jdbc/Hibernate3/EJB3
在Hibernate中有三種狀態(tài),對(duì)它的深入理解,才能更好的理解hibernate的運(yùn)行機(jī)理,剛開(kāi)始不太注意這些概念,后來(lái)發(fā)現(xiàn)它是重要的。對(duì)于理解hibernate,JVM和sql的關(guān)系有更好的理解。對(duì)于需要持久化的JAVA對(duì)象,在它的生命周期中有三種狀態(tài),而且互相轉(zhuǎn)化。
1, 臨時(shí)狀態(tài)(Transient):用new創(chuàng)建的對(duì)象,它沒(méi)有持久化,沒(méi)有處于Session中,處于此狀態(tài)的對(duì)象叫臨時(shí)對(duì)象;
2, 持久化狀態(tài)(Persistent):已經(jīng)持久化,加入到了Session緩存中。如通過(guò)hibernate語(yǔ)句保存的對(duì)象。處于此狀態(tài)的對(duì)象叫持久對(duì)象;
3, 游離狀態(tài)(Detached):持久化對(duì)象脫離了Session的對(duì)象。如Session緩存被清空的對(duì)象。
特點(diǎn):已經(jīng)持久化,但不在Session緩存中。處于此狀態(tài)的對(duì)象叫游離對(duì)象;
×√ |
臨時(shí)狀態(tài)
(Transient) |
持久化狀態(tài)
(Persistent) |
游離狀態(tài)
(Detached) |
是否處于Session緩存中 |
× |
√ |
× |
數(shù)據(jù)庫(kù)中是否有對(duì)應(yīng)記錄 |
× |
√ |
√ |
|
|
|
|

游離對(duì)象和臨時(shí)對(duì)象異同:
兩者都不會(huì)被Session關(guān)聯(lián),對(duì)象屬性和數(shù)據(jù)庫(kù)可能不一致;
游離對(duì)象有持久化對(duì)象關(guān)閉Session而轉(zhuǎn)化而來(lái),在內(nèi)存中還有對(duì)象所以此時(shí)就變成游離狀態(tài)了;
Hibernate和SQL的關(guān)系:
在操作了hibernate的方法如save()等后,并沒(méi)有直接生成sql語(yǔ)句,去操作數(shù)據(jù)庫(kù),而是把這些更新存入Session中,只有Session緩存要被更新時(shí),底層的sql語(yǔ)句才能執(zhí)行,數(shù)據(jù)存入數(shù)據(jù)庫(kù);
下面舉例說(shuō)明:
一,Session.save(user)運(yùn)行機(jī)理。
1,把User對(duì)象加入緩存中,使它變成持久化對(duì)象;
2,選用映射文件指定的標(biāo)識(shí)生成ID;
3,在Session清理緩存時(shí)候執(zhí)行:在底層生成一個(gè)insert sql語(yǔ)句,把對(duì)象存入數(shù)據(jù)庫(kù);
注意:在你執(zhí)行Session.save(user)后,在Session清理緩存前,如果你修改user對(duì)象屬性值,那么最終存入數(shù)據(jù)庫(kù)的值將是最后修改的值;此過(guò)程中ID不能被修改;
二,Session.delete(user)運(yùn)行過(guò)程。
如果user是持久化對(duì)象,則執(zhí)行刪除操作,同樣底層數(shù)據(jù)庫(kù)的執(zhí)行條件是:在Session清理緩存時(shí)候;
如果user是游離對(duì)象:
1,將user對(duì)象和Session關(guān)聯(lián),使之成為持久化對(duì)象;
2,然后按照user 是持久化對(duì)象的過(guò)程執(zhí)行;