欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-24 20:52:17
目录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 ,这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。

: 可能出现 : 不会出现

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

未提交读

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+就已经抛弃了这样的查询方法,

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

在mysql 8.0.3 中,该变量已经被 transaction_isolation 替换了。

最新的查询方法有多种,下面提供2种:

1、select @@transaction_isolation;

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

2、show variables like ‘transaction_isolation';

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。