设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 站长学院 > MySql教程 > 正文

事务隔离级别

发布时间:2022-06-28 11:44 所属栏目:115 来源:互联网
导读:事务隔离是数据库处理的基础之一,Isolation是ACID中I的缩写,当多个事务同时进行更改和执行查询时,隔离级别是微调性能和可靠性、一致性和结果再现性之间的平衡的设置 MySQL支持以下几个隔离级别 REPEATABLE READ (innodb使用的默认级别) READ COMMITTED REA
  事务隔离是数据库处理的基础之一,Isolation是ACID中I的缩写,当多个事务同时进行更改和执行查询时,隔离级别是微调性能和可靠性、一致性和结果再现性之间的平衡的设置
  MySQL支持以下几个隔离级别
  REPEATABLE READ (innodb使用的默认级别)
  READ COMMITTED
  READ UNCOMMITTED
  SERIALIZABLE
  REPEATABLE READ(当执行一个范围查询时,会发生幻读问题)
  这是innodb默认的隔离级别,同一事务中的一致读读取由第一个读取建立的快照,意味着如果你在同一个事务中发送多次一样(没有锁的)的select语句,这些SELECT语句返回的结果在相互之间也是一致的。
  READ COMMITTED(有不可重复读问题)
  每一个一致读,即使在同一事务中,都会设置并读取它自己的新快照
  READ UNCOMMITTED(有脏读问题)
  SELECT语句是在一个非锁定的方式进行,但是有可能会使用更早版本的行数据,因此,使用这个隔离级别,读不是一致的,称之为脏读,否则,此隔离级别工作机制类似于
  SERIALIZABLE(脏读,不可重复读,幻读问题都不会发生)
  这个级别有点像REPEATABLE READ,但是innodb隐式的将所有SELECT语句传唤成SELECT ... LOCK IN SHARE MODE除了autocommit 被禁止这种情况,如果启用autocommit,则SELECT是它自己的事务。
  事务隔离主要的作用在于解决并发带来的脏读,不可重复读,幻读问题,详细内容请看我的下一篇文章。

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读