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

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

root4年前 (2022-01-13)数据库1018
禁止自动提交
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

分享给朋友:

相关文章

postgresql 导入导出sql 文件

pg_dump  -h localhost -U postgres -t tablename databasename >./test.sql导出 -t 表名  psql -d test1 -U...

centos7 安装mysql

centos7 安装mysql

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

postgresql修改数据存储位置

postgresql修改数据存储位置

最近公司提供了一台新的服务器,同时有一个盘是ssd。同时为了测试postgresql的性能,将数据放置到ssd上系统centos7.9 数据库postgresql-9.6首先停掉数据库systemctl stop pos...

被Navicat坑哭的日常,版本问题

mysql5.7DROP TABLE IF EXISTS `xxx_copy1`;CREATE TABLE `xxx_copy1`  (  `id` int(11) UNSIGNED NOT NULL AUTO_INCR...

清空postgresql的缓存

系统:centos,版本:postgresql-9.6因为要测试postgresql的性能,当多次查询的时候查询结果会因为缓存用时很短,不能模拟出现实使用的场景。因此需要清除缓存。首先stop掉postgresqlsystemctl sto...

postgresql 查看数据库、表的大小

查看数据库的大小 select pg_database_size('test'); select pg_size_pretty(pg_database_size('test');查看单...