成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Hibernate的事務:事務對象的方法

開發 后端
Hibernate的事務保證原子操作的不可分,也就是操作的同時成功或同時失敗。hibernate的事務隔離級別和JDBC中大致相同。

Hibernate在發送Sql把對象信息同步到數據時,不是立即進行的而是把這些要發送的Sql緩存在起來,在必要的時候發送。

通過Session的setFlushMode(FlushMode flushMode)方法,來控制在什么時候清空Sql的緩沖區,并把緩存的Sql語句發送出去。

FlushMode是一個枚舉,它有3個枚舉值。

FlushMode.AUTO,在持久化對象的信息被修改時,那么就要把它同步到數據庫中,更新數據庫中隊應的記錄,也就是在產生修改時就會清空緩沖區。

FlushMode.COMMIT,只有在事務提交的時候才清空緩沖區。

FlushMode.NEVER,這個值表示只有在調用了Session的flush()方法才清空緩沖區。

Hibernate的事務保證原子操作的不可分,也就是操作的同時成功或同時失敗。

Transaction tran=session.beginTranaction();

tran.commit();

tran.rollback();

以上是Hibernate的事務對象的方法,來實現對事務的支持。

hibernate的事務隔離級別

hibernate的事務隔離級別和JDBC中大致相同。

設置時要在hibernate.cfg.xml配置

< property name="hibernate.connection.isolation">4< /property>

1,讀未提交的數據(Read uncommitted isolation)

2,讀已提交的數據(Read committed isolation)

4,可重復讀級別(Repeatable read isolation)

8,可串行化級別(Serializable isolation)

hibernate的鎖(悲觀鎖,樂觀鎖)

悲觀鎖是由數據庫本身所實現的,會對數據庫中的數據進行鎖定,也就是鎖行。

LockMode.UPGRADE,修改鎖,在get()方法中加上這個設置作為第三個參數。

LockMode.NONE 無鎖機制

LockMode.READ 讀取鎖

LockMode.WRITE 寫入鎖,不能在程序中直接使用

還可以使用Session.lock() Query.setLockMode() Criteria.setLockMode()方法來設置鎖

樂觀鎖,也就是通過對記錄加上某些信息來解決并發訪問的問題。

版本檢查

要在其表中多加上一個字段表示版本信息,會在讀取時讀到這個版本號,并在修改之后更新這個版本號,在并發修改的時,只有數據庫中記錄的版本號比要更新的才進行更新操作,如果數據庫記錄版本號比要更新的高,就會拋出例外。

寫在Xxxxx.hbm.xml中

< version name="version" column="version" type="integer" />

例:

  1. public class User implements Serializable{  
  2.  
  3.     private int id;  
  4.  
  5.     private String name;  
  6.  
  7.     private String phone;  
  8.  
  9.     private int version;//記錄版本的屬性  
  10.  
  11.     public int getId(){  
  12.  
  13.         return id;  
  14.  
  15.     }  
  16.  
  17.  
  18.  
  19.     public void setId(int id){  
  20.  
  21.         this.id = id;  
  22.  
  23.     }  
  24.  
  25.  
  26.  
  27.     public String getName(){  
  28.  
  29.         return name;  
  30.  
  31.     }  
  32.  
  33.  
  34.  
  35.     public void setName(String name){  
  36.  
  37.         this.name = name;  
  38.  
  39.     }  
  40.  
  41.  
  42.  
  43.     public String getPhone(){  
  44.  
  45.         return phone;  
  46.  
  47.     }  
  48.  
  49.  
  50.  
  51.     public void setPhone(String phone){  
  52.  
  53.         this.phone = phone;  
  54.  
  55.     }  
  56.  
  57.  
  58.  
  59.     public int getVersion(){  
  60.  
  61.         return version;  
  62.  
  63.     }  
  64.  
  65.  
  66.  
  67.     public void setVersion(int version){  
  68.  
  69.         this.version = version;  
  70.  
  71.     }     
  72.  
  73.       
  74.  
  75. }  

User類的User.hbm.xml文件

  1. < hibernate-mapping package="alan.hbn.concur.version" auto-import="false"> 
  2.  
  3.      < class name="User" table="user_version"> 
  4.  
  5.          < id name="id" column="id" type="integer" unsaved-value="0"> 
  6.  
  7.               < generator class="native"/> 
  8.  
  9.          < /id> 
  10.  
  11.          < version name="version" column="version" type="integer" /> 
  12.  
  13.          < !--版本控制,指定了版本屬性的名字,和對應表中的字段和類型--> 
  14.  
  15.          < property name="name" column="name"/> 
  16.  
  17.          < property name="phone" column="phone"/>          
  18.  
  19.     < /class> 
  20.  
  21. < /hibernate-mapping> 

【編輯推薦】

  1. Hibernate緩存簡介及分類
  2. Hibernate中generator屬性的意義
  3. hibernate Key Generator 主鍵生成方式
  4. Hibernate的主鍵生成機制
  5. hibernate的Query cache 
     
責任編輯:book05 來源: 163博客
相關推薦

2009-09-23 17:41:05

Hibernate事務

2009-06-03 10:20:11

Hibernate事務管理配置

2009-06-03 10:49:48

Hibernate事務

2009-09-25 11:27:19

Hibernate J

2009-09-25 12:59:53

Hibernate事務

2009-09-24 14:12:22

Hibernate數據

2017-01-19 15:32:36

Java全局事務本地事務

2009-09-29 09:44:52

Hibernate事務

2012-02-02 15:57:09

HibernateJava

2009-09-23 17:48:00

Hibernate事務

2009-06-26 16:31:50

區分不同對象Hibernate

2011-03-25 10:00:23

Spring3.0事務的配置

2009-06-12 09:49:25

EJB事務屬性EJB事物

2010-11-22 16:40:00

MySQL事務表

2009-07-23 13:30:46

JDBC事務

2020-07-17 08:07:54

Spring數據庫事務

2009-07-08 14:01:47

Servlet容器

2010-10-11 09:25:06

定義MySQL事務

2023-10-30 07:36:19

Spring事務傳播機制

2024-04-29 07:42:20

數據庫Mybatis事務
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 超碰人人做 | 国产1页| 欧美精品久久久 | 狠狠伊人 | 91精品国产综合久久国产大片 | 黄色在线观看网站 | 自拍偷拍中文字幕 | www.av在线 | 一级毛片在线播放 | 国产一区免费视频 | 久久久精品网站 | www.久草| 成人av网站在线观看 | 日韩精品一区二区三区中文字幕 | 精品国产高清一区二区三区 | 久久久久久久久久久久一区二区 | 91精品久久久久久久 | 国产情侣在线看 | 亚州精品天堂中文字幕 | 二区在线观看 | 国产精品乱码一区二区三区 | 国产精品久久久久久久久大全 | 精品一区在线看 | 国产精品视频偷伦精品视频 | 91中文字幕 | 亚洲成人蜜桃 | 午夜私人影院在线观看 | 91毛片在线看 | 国产高清精品一区二区三区 | 日本久久精品视频 | 99欧美精品 | 狠狠涩| 久久不射电影网 | a精品视频| 欧美视频精品 | 亚洲精品在线免费播放 | 精品欧美乱码久久久久久1区2区 | 在线综合视频 | 日韩在线精品视频 | 亚洲理论在线观看电影 | 精品日韩一区二区 |