隔离级别和事务

数据库事务

结合基本例子(银行转账)来分析:

AB账户都有500元存款,A账户向B账户转账100元钱 ,操作分为6步

  1. 取出A账户余额为500元
  2. 把500元转出100,还剩400元
  3. 将400元存入A的账户中
  4. 取出B的余额为500元
  5. 将B的500元加上100元,总共600元
  6. 将600元存入B的账户中

事务有四大特性(ACID)

  1. 原子性(Atomicity):所有的操作要么都成功,要么都失败回滚,恢复之前状态。如上6步操作,任何一步操作失败,AB账户不受任何影响。
  2. 一致性(Consistency): 事务必须使数据库从一个状态整体变到另一个状态,就是执行前后,必须保持状态一致。相当于转账前AB加起来一共1000元,不管中间进行几次转账,最终两人加起来还得是1000元。
  3. 隔离性(Isolation):多事务并发执行,相互之间不存在影响。事务没有提交之前,其他事务读取的数据还是修改之前的数值。相当于AC都向B转账,A和C向B转账的过程中,其他事务读取B的余额还是500元,直到AC两个事务提交成功,B的账户应该就是700元。
  4. 持久性(Druability):一旦事务被提交,对数据库的改变就是永久的。一旦转账事务提交成功,数据库数据将永久被改变。

数据库隔离级别

  1. 未提交读:
    事务进行的修改,即使没有提交,对于其他事务也是可见的
  2. 提交读:
    大部分数据库用这个(mysql不是),事务在开始到提交前,进行的修改对其他事务都是不可见的,因为会出现不可重复读,两次读到的数据不一致
  3. 可重复读:
    mysql数据库默认使用的这种,保证了一个事务中多次读取同样的数据保持结果一致。但是不能避免幻读现象(事务读取某范围内记录,另外事务插入一行,再次读取,就会产生幻行)
  4. 可串行化:
    最高的隔离级别,强制事务串行执行,避免幻读问题,会在读取的每一行数据上加锁,可能会导致大量超时和锁争用。

InnoDB存储引擎

InnoDB的MVCC(多版本并发控制),通过在每行记录后面增加两个隐藏列,保存行创建时系统版本号和删除时的版本号。
优点:大部分读操作不用加锁,保证只能读到符合标准的行
缺点:每行记录需要增加额外的存储空间

默认使用的隔离级别是REPEATABLE READ(可重复读),并且采用间隙锁策略防止幻读。(删除一个不存在的记录,就会扫描索引,找到第一个比给定参数小的值,找到第一个比给定参数大的值,这样形成一个区间,锁住这个区间,就是间隙锁,这样容易出现死锁)

MyISAM存储引擎

对整张表加锁,读数据时加共享锁,写数据时加排他锁,但是在表有读取数据的查询时,还是可以往表中插入数据(并发插入)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容