首頁 > 資料庫 > mysql教程 > 事务的隔离级别

事务的隔离级别

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 16:05:07
原創
1222 人瀏覽過

数据库系统有四个隔离级别,分别为未提交读、已提交读、可重复读、串行化 大多数数据库的默认级别就是Read committed,比如Sql Server , Oracle。Mysql的默认隔离级别就是Repeatable read。 READ UNCOMMITTED(未提交读) 事务A执行的操作未提交,但是事务B还

数据库系统有四个隔离级别,分别为未提交读、已提交读、可重复读、串行化

大多数数据库的默认级别就是Read committed,比如Sql Server , Oracle。Mysql的默认隔离级别就是Repeatable read。

READ UNCOMMITTED(未提交读)

事务A执行的操作未提交,但是事务B还是能看到修改,这时会产生脏读的情况。

READ COMMITTED(提交读)

事务A先是读取了数据,这时事务B更改了同一数据,并已提交,这时事务A再次读取这个数据时就会发现两次数据不一致,这就产生不可重复读的现象。

REPEATABLE READ(可重复读)

当事务A读取记录时,会对此记录添加一个共享锁,即事务B不能在事务A结束前对记录进行修改。

可能产生的问题:当执行范围查询时,可能会产生幻读。如事务A先查询一个消费总量,接着事务B增加一条消费记录,这时事务A再次查询消费总量时,就会发现两次查询不一致

SERIALIZABLE(序列化)

添加范围锁(比如表锁,页锁等、),直到transaction A结束。以此阻止其它transaction B对此范围内的insert,update等操作。幻读,脏读,不可重复读等问题都不会发生。

 

脏读

不可重复读

幻读

Read uncommitted

Read committed

×

Repeatable read

×

×

Serializable

×

×

×


相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
JavaScript事件
來自於 1970-01-01 08:00:00
0
0
0
javascript - DOM事件模型
來自於 1970-01-01 08:00:00
0
0
0
objective-c - iOS 系統行事曆插入事件失敗
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板