自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Hibernate update淺談

開發(fā) 后端
這里介紹Hibernate update操作的是在自由態(tài)或脫管狀態(tài)(因session的關(guān)閉而處于脫管狀態(tài))的對(duì)象//updateSQL,而flush是操作的在持久狀態(tài)的對(duì)象。

在所有之前,說明一下,對(duì)于Hibernate,它的對(duì)象有三種狀態(tài),transient、persistent、detached

下邊是常見的翻譯辦法:
◆transient:瞬態(tài)或者自由態(tài)(new DeptPo(1,”行政部”,20,”行政相關(guān)”),該po的實(shí)例和session沒有關(guān)聯(lián),該po的實(shí)例處于transient)
◆persistent:持久化狀態(tài)(和數(shù)據(jù)庫中記錄想影射的Po實(shí)例,它的狀態(tài)是persistent, 通過get和load等得到的對(duì)象都是persistent)
◆detached:脫管狀態(tài)或者游離態(tài)
(1)當(dāng)通過get或load方法得到的po對(duì)象它們都處于persistent,但如果執(zhí)行delete(po)時(shí)(但不能執(zhí)行事務(wù)),該 po狀態(tài)就處于detached, (表示和session脫離關(guān)聯(lián)),因delete而變成游離態(tài)可以通過save或saveOrUpdate()變成持久態(tài)
(2)當(dāng)把session關(guān)閉時(shí),session緩存中的persistent的po對(duì)象也變成detached

Hibernate update和flush區(qū)別

Hibernate update操作的是在自由態(tài)或脫管狀態(tài)(因session的關(guān)閉而處于脫管狀態(tài))的對(duì)象//updateSQL,而flush是操作的在持久狀態(tài)的對(duì)象。

默認(rèn)情況下,一個(gè)持久狀態(tài)的對(duì)象的改動(dòng)(包含set容器)是不需要update的,只要你更改了對(duì)象的值,等待Hibernate flush就自動(dòng)更新或保存到數(shù)據(jù)庫了。Hibernate flush發(fā)生在以下幾種情況中:
1, 調(diào)用某些查詢的和手動(dòng)flush(),session的關(guān)閉、SessionFactory關(guān)閉結(jié)合。get()一個(gè)對(duì)象,把對(duì)象的屬性進(jìn)行改變,把資源關(guān)閉。
2,transaction commit的時(shí)候(包含了flush)

Hibernate update和lock區(qū)別

Hibernate update是把一個(gè)已經(jīng)更改過的脫管狀態(tài)的對(duì)象變成持久狀態(tài)

lock是把一個(gè)沒有更改過的脫管狀態(tài)的對(duì)象變成持久狀態(tài)(針對(duì)的是因Session的關(guān)閉而處于脫管狀態(tài)的po對(duì)象(2),不能針對(duì)因delete而處于脫管狀態(tài)的po對(duì)象)

對(duì)應(yīng)更改一個(gè)記錄的內(nèi)容,兩個(gè)的操作不同:
◆update的操作步驟是:屬性改動(dòng)后的脫管的對(duì)象的修改->調(diào)用update
◆lock的操作步驟是:調(diào)用lock把未修改的對(duì)象從脫管狀態(tài)變成持久狀態(tài)-->更改持久狀態(tài)的對(duì)象的內(nèi)容-->等待flush或者手動(dòng)flush

clear和evcit的區(qū)別

clear完整的清除session緩存。evcit(obj)把某個(gè)持久化對(duì)象從session的緩存中清空。
session.lock(xtyhb,LockMode.NONE);
//表示直接到緩存中去找變成持久態(tài)的對(duì)象
session.lock(xtyhb,LockMode.READ);
//先通過ID讀數(shù)據(jù)庫該記錄的ID看是否有該記錄,如果有接著到緩存中去找變成持久態(tài)的對(duì)象

【編輯推薦】

  1. iBATIS與Hibernate間的取舍
  2. JDBC與Hibernate讀取性能分析
  3. 淺析NHibernate一對(duì)一映射的延遲加載
  4. 使用Hibernate 3二級(jí)緩存的四個(gè)經(jīng)驗(yàn)
  5. MySQL存儲(chǔ)過程中的Hibernate JDBC
責(zé)任編輯:佚名 來源: IT168
相關(guān)推薦

2009-09-23 17:07:31

Hibernate C

2009-09-28 15:47:59

Hibernate O

2009-09-23 15:50:21

Hibernate u

2009-06-18 11:43:40

Hibernate uHibernate s

2009-09-25 10:53:40

Hibernate S

2009-09-22 10:09:21

Hibernate S

2009-09-29 10:46:58

Hibernate領(lǐng)域

2009-09-28 13:43:28

使用Hibernate

2009-09-22 13:41:10

直接使用Hiberna

2009-09-28 13:39:01

Hibernate工作

2009-09-27 10:02:29

定制Hibernate

2009-09-29 16:16:58

Hibernate H

2009-09-21 17:17:11

Hibernate二級(jí)

2009-09-29 15:52:26

Hibernate X

2009-09-27 14:06:57

Hibernate o

2009-06-24 08:02:15

Hibernateupdate與save

2009-09-23 14:40:17

Hibernate F

2009-02-11 09:37:32

Hibernate分頁技術(shù)JSP

2009-09-25 09:21:27

Hibernate元數(shù)

2009-06-10 09:58:32

Oracle sequHibernate
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)