当前位置:首页 > 数据库 > 正文内容

mysql事务的四个隔离机制理解

root2年前 (2022-01-13)数据库467
禁止自动提交
SET AUTOCOMMIT=0 
开启自动提交
SET AUTOCOMMIT=1 

读未提交
//设置read uncommitted级别:
set session transaction isolation level read uncommitted;
读已提交
//设置read committed级别:
set session transaction isolation level read committed;
可重复读
//设置repeatable read级别:
set session transaction isolation level repeatable read;
串行化
//设置serializable级别:
set session transaction isolation level serializable;


事务隔离级别

是指两个事务之间,在一个事务修改内容的情况下,另外一个事务查询数据过程的隔离级别

读未提交:

    设事务A和事务B,

    开启事务A、开启事务B

    事务B查询某数据

    事务A更新该数据,并未提交。

    事务B查询该数据,发现与上次查询不一致

即事务在未提交的情况下,另外一个事务中是可以查询到更新后的数据


读已提交:

    设事务A和事务B,

    开启事务A、开启事务B

    事务B查询某数据

    事务A更新该数据,并未提交。

    事务B查询该数据,发现与上次查询一致

    事务A提交(commit)

    事务B查询该数据,发现与上次查询不一致

即事务在未提交的情况下,另外一个事务中是查询不到修改的数据

    事务在提交的情况下,另外一个事务中是可以查询到更新后的数据


可重复读:

    设事务A和事务B,

    开启事务A、开启事务B

    事务B查询某数据

    事务A更新该数据,并未提交。

    事务B查询该数据,发现与上次查询一致

    事务A提交(commit)

    事务B查询该数据,发现与上次查询一致

即事务在未提交的情况下,另外一个事务中是查询不到修改的数据

    事务在提交的情况下,另外一个事务中是查询不到修改的数据


串行化:

    开启任意一个事务就会锁表,开发中很少用到;



参考



扫描二维码推送至手机访问。

版权声明:本文由一叶知秋发布,如需转载请注明出处。

本文链接:https://zhiqiu.top/?id=206

分享给朋友:

相关文章

mysql 临时表和复制表

创建临时表CREATE TEMPORARY TABLE SalesSummary  (product_name VARCHAR(50) NOT NULL, ...

centos7 安装mysql

centos7 安装mysql

下载rpm包wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm 安裝包仓库yum -y install * 或者yum -...

dataX:超强的数据库数据互导工具

安装下载安装包http://datax-opensource.oss-cn-hangzhou.aliyuncs.com/datax.tar.gz 然后解压进入解压后文件的./bin自检命令python  datax.py ../j...

mysql 导出csv格式数据

mysql -e "select * from newsdb.t_hk_stock_news where id <100  ...

mysql 主键 用int还是long 还是char?有什么区别

char是定长0-255 bytes longtext是0-4 294 967 295 bytes 极大文本数据longblob是二进制形式的极大文本数据...

clickhouse 分区、分片简单理解

clickhouse 分区、分片简单理解

分区是表的分区,具体的DDL操作关键词是 PARTITION BY,指的是一个表按照某一列数据(比如日期)进行分区,对应到最终的结果就是不同分区的数据会写入不同的文件中。分片复用了数据库的分区,相当于在原有的分区下,作为第二层分区...