加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.0577zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL的事务隔离等级介绍

发布时间:2022-01-19 00:27:25 所属栏目:MySql教程 来源:互联网
导读:本篇内容介绍了MySQL的事务隔离级别介绍的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 什么是事务? 数据库事务(简称:事务)是数据库管理系统执
        本篇内容介绍了“MySQL的事务隔离级别介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
  
什么是事务?
        数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。—— 维基百科
 
        事务的概念看上去不难,但是需要注意以下几个点:
 
1、首先,事务就是要保证一组数据库操作,要么全部成功,要么全部失败;
 
2、在 MySQL 中,事务支持是在引擎层实现的;
 
3、并不是所有引擎都支持事务,如 MyISAM 就不支持,InnoDB 就支持;
 
今天,我们的主角是隔离性,隔离性是指当多个用户并发操作数据库时,数据库为每一个用户开启不同的事务,这些事务之间相互不干扰,相互隔离。
 
为什么需要隔离性?
如果事务之间不是互相隔离的,可能将会出现以下问题。
 
1、脏读
脏读(dirty read),简单来说,就是一个事务在处理过程中读取了另外一个事务未提交的数据。
 
这种未提交的数据我们称之为脏数据。依据脏数据所做的操作肯能是不正确的。
 
还记得上节中我们提到的 dirty page 吗?这种临时处理的未提交的,都是「脏」的。
  
但是,若该事务未提交成功,最终所有操作都会回滚,小编看到的一分钱也只是镜花水月。比如,你给小编赞赏 1 分钱,整个事务需要两个步骤:
 
①给小编账号加一分钱,这时小编看到了,觉得很欣慰;
②你的账号减一分钱;
  
2、不可重复读
不可重复读(non-repeatable read),是指一个事务范围内,多次查询某个数据,却得到不同的结果。
 
在第一个事务中的两次读取数据之间,由于第二个事务的修改,第一个事务两次读到的数据可能就是不一样的。
 
 

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读