目录
- mysql8.0 查看事务隔离级别报错
- mysql的事务隔离级别(包含mysql8.0+设置与查看)
- 一、事务的基本要素(acid)
- 三、mysql事务隔离级别 事务的隔离级别分为
- mysql 8.0+ 查询数据库事务隔离级别
mysql8.0 查看事务隔离级别报错
问题
数据库查看事务隔离级别
select @@global.tx_isolation,@@tx_isolation;
报错:
mysql> select @@global.tx_isolation,@@tx_isolation;
error 1193 (hy000): unknown system variable ‘tx_isolation’
mysql> select @@global.tx_isolation,@@tx_isolation;
error 1193 (hy000): unknown system variable ‘tx_isolation’
我用的mysql8.0版本。tx_isolation在8.0版本更改为global.transaction_isolation
命令更改为
select @@global.transaction_isolation,@@transaction_isolation;
mysql的事务隔离级别(包含mysql8.0+设置与查看)
mysql的四种事务隔离级别
一、事务的基本要素(acid)
1、原子性(atomicity):事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节。事务执行过程中出错,会回滚到事务开始前的状态,所有的操作就像没有发生一样。也就是说事务是一个不可分割的整体,就像化学中学过的原子,是物质构成的基本单位。
2、一致性(consistency):事务开始前和结束后,数据库的完整性约束没有被破坏 。比如a向b转账,不可能a扣了钱,b却没收到。
3、隔离性(isolation):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰。比如a正在从一张银行卡中取钱,在a取钱的过程结束前,b不能向这张卡转账。
4、持久性(durability):事务完成后,事务对数据库的所有更新将被保存到数据库,不能回滚。
二、事务的并发问题
1、脏读:事务a读取了事务b更新的数据,然后b回滚操作,那么a读取到的数据是脏数据
2、不可重复读:事务 a 多次读取同一数据,事务 b 在事务a多次读取的过程中,对数据作了更新并提交,导致事务a多次读取同一数据时,结果 不一致。
3、幻读:系统管理员a将数据库中所有学生的成绩从具体分数改为abcde等级,但是系统管理员b就在这个时候插入了一条具体分数的记录,当系统管理员a改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。
小结:不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表
三、mysql事务隔离级别 事务的隔离级别分为
未提交读(read uncommitted)、已提交读(read committed)、可重复读(repeatable read)、串行化(serializable)。
四种级别由低到高依次为read uncommitted 、read committed 、repeatable read 、serializable ,这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。
是: 可能出现 否: 不会出现
未提交读
a事务已执行,但未提交;b事务查询到a事务的更新后数据;a事务回滚;—出现脏数据
已提交读
a事务执行更新;b事务查询;a事务又执行更新;b事务再次查询时,前后两次数据不一致;—不可重复读
可重复读
a事务无论执行多少次,只要不提交,b事务查询值都不变;b事务仅查询b事务开始时那一瞬间的数据快照;—幻读
串行化
不允许读写并发操作,写执行时,读必须等待;
四、数据库设置
//查看当前事物级别(mysql8.0以上版本不适用, 请看下面): select @@tx_isolation; //设置mysql的隔离级别: set session transaction isolation level;设置事务隔离级别 //设置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;
mysql 8.0+ 查询数据库事务隔离级别
根据慕课网课程中的方法,查询事务隔离级别使用:
select @@tx_isolation;
我在sequal pro中,却提示错误:unknown system variable ‘tx_isolation’
查询了官方文档,在8.0+就已经抛弃了这样的查询方法,
在mysql 8.0.3 中,该变量已经被 transaction_isolation 替换了。
最新的查询方法有多种,下面提供2种:
1、select @@transaction_isolation;
2、show variables like ‘transaction_isolation’;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持www.887551.com。