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

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

root5年前 (2022-01-13)数据库1565
禁止自动提交
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启动失败 日志InnoDB: Ignoring the redo log due to missing MLOG_CHECKPOINT between the checkpoint 3485

mysql报错Ignoring the redo log due to missing MLOG_CHECKPOINT betweenmysql版本:5.7.33系统版本:ubuntu16.04由于电脑突然关闭,跑在VMware里面的mys...

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

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

postgresql 导入导出sql 文件

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

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...