解决MySql8.0 查看事务隔离级别报错的问题

目录
  • 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。

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐