mysql rr和rc_MySQL--事务隔离级别RR和RC的异同详解

在MySQL中,事务隔离级别RC(read commit)和RR(repeatable read)两种事务隔离级别基于多版本并发控制MVCC(multi-version concurrency control)来实现。

由于RC隔离级别需要保持语句级别的一致行,事务中每一次读取都是访问当前时间点的已提交数据,因此事务中多条查询语句会创建多个不同的ReadView,开销较大,复杂度更高,而对于RR隔离级别,仅需要一个版本的ReadView,消耗更少,因此Mysql默认使用RR隔离级别。

RC隔离级别获得的是语句级读一致性

RR隔离级别获得的是事务级读一致性

当使用基于语句格式的Binlog时,Innodb存储引擎不支持READ COMMITTED和READ UNCOMMITTED两种事务隔离级别,否则无法保证主从数据一致。

错误消息:ERROR 1598 (HY000): Binary logging not possible. Message: Transaction

level 'READ-COMMITTED' in InnoDB is not safe for binlog mode 'STATEMENT'

对于RR隔离级别,事务执行所持有的锁会被持有到事务结束。

对于RC隔离级别,事务执行时所持有的行锁,如果该行数据未被修改,则在语句结束后被释放。

如对于SQL: update tb001 set c1=0 where c1=1; 表tb001上c1列没有索引,语句执行时需要扫描全表数据并对每行数据加锁,在RC隔离级别下,仅有满足c1=1的行数据被修改且锁被保留到事务结束,而RR隔离级别下,

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 中的并发控制和事务隔离级别是很重要的概念。在多个用户同时访问同一个数据库的情况下,如果不进行并发控制,就会出现数据不一致的问题。而事务隔离级别是指在多个事务同时执行的情况下,如何保证每个事务之间的数据隔离性。MySQL 支持多种隔离级别,包括: 1. 读未提交(Read Uncommitted):最低的隔离级别,允许一个事务读取另一个事务尚未提交的数据。这种隔离级别会导致脏读、不可重复读和幻读的问题。 2. 读已提交(Read Committed):允许一个事务只能读取另一个事务已经提交的数据。这种隔离级别可以解决脏读的问题,但是可能会出现不可重复读和幻读的问题。 3. 可重复读(Repeatable Read):允许一个事务读取另一个事务已经提交的数据,并且在事务结束之前,其他事务不能修改这些数据。这种隔离级别可以解决脏读和不可重复读的问题,但是可能会出现幻读的问题。 4. 串行化(Serializable):最高的隔离级别,确保每个事务都独立运行,没有并发问题。但是串行化会导致性能下降,因为它会锁定所有读取的数据。 在 MySQL 中,默认的隔离级别是可重复读。可以使用 SET TRANSACTION ISOLATION LEVEL 命令来设置隔离级别。同时,可以使用行级锁和表级锁来实现并发控制。行级锁可以锁定单独的行,而表级锁可以锁定整个表。在实际应用中,需要根据实际情况选择合适的隔离级别和锁的类型来保证数据的一致性和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值