zoukankan      html  css  js  c++  java
  • 浅谈数据库事务隔离

    事务隔离主要是针对ACID中的 I 隔离性设置的,在了解这几种数据库事务之前需要先了解几个重要概念:

    • 脏读 - 事务1(READ)访问了事务2(WRITE)未提交的事务

      2154loev8R53

    • 幻读 - 一个事务读取了2次,得到的结果不一样

      2155aZxX8o26

    • 不可重复读 - 一个事务读取同一条记录2次,得到的结果不一致

      2156wuH3uE40

    为了解决上面的三个问题,有四种数据库隔离级别

    1. READ UNCOMMITTED

      故名思义,读未提交,允许脏读,当然也会出现不可重复读和幻读,可以通过“排他写锁”实现,在表对某行进行修改时,会对该行加上行共享锁

    2. READ COMMITTED

      读提交,允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。在本事务未提交之前其他事务的增删改操作提交后会影响读的结果。 读的是最新结果 。在对表进行修改时,会对表数据行加上行共享锁

    3. Repeatable Read

      可重复读,禁止不可重复读取和脏读取,但是有时可能出现幻读数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。读的是快照结果。MysQL 默认级别,通过MVCC解决了幻读问题。在事务中对某条记录修改,会对记录加上行共享锁,直到事务结束才会释放。

    4. Serializable

      序列化,提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,不能并发执行。仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。

      进行查询时就会对表或行加上共享锁,其他事务对该表将只能进行读操作,而不能进行写操作。

      2203eTpuhO46

    事务隔离级别越高,数据的完整性和一致性越好,但会影响并发性能。mysql默认使用 Repeatable Read 级别,而aliyun rds 默认使用 READ COMMITTED。

    查看查询数据库隔离级别

    select @@global.tx_isolation;
    

    Mysql 8.0 以上需要使用

    select @@transaction_isolation;
    

    修改事务隔离级别:mysql.ini

    #可选参数有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.
    [mysqld]
    transaction-isolation = REPEATABLE-READ
    

    当然,也可以只对当前session修改

    mysql> set session transaction isolation level read uncommited;
    

    锁机制

    共享锁:由读表操作加上的锁,加锁后其他用户只能获取该表或行的共享锁,不能获取排它锁,也就是说只能读不能写

    排它锁:由写表操作加上的锁,加锁后其他用户不能获取该表或行的任何锁,典型是mysql事务中的

    锁的范围:

    行锁: 对某行记录加上锁

    表锁: 对整个表加上锁

    本文由 歧途老农 创作,采用 CC BY 4.0 CN 协议 进行许可。 可自由转载、引用,但需署名作者且注明文章出处。

  • 相关阅读:
    02 . Vue入门基础之条件渲染,列表渲染,事件处理器,表单控件绑定
    iptables防火墙简介,原理,规则编写,做网络防火墙,常见案例
    Go之发送钉钉和邮箱
    Jumpserver简介,部署及使用
    01 . Go语言实现SSH远程终端及WebSocket
    KVM简介,安装及常见使用,维护详解
    05 . Gin+Vue开发一个线上外卖应用(Session集成及修改用户头像到Fastdfs)
    04 . Gin+Vue开发一个线上外卖应用(用户名密码和图形验证码)
    03 . Gin+Vue开发一个线上外卖应用(用户数据创建,插入,跨域处理)
    02 . Go之Gin+Vue开发一个线上外卖应用(集成第三方发送短信和xorm生成存储数据库表)
  • 原文地址:https://www.cnblogs.com/whereis/p/13294044.html
Copyright © 2011-2022 走看看