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

吾爱主题 阅读:207 2024-04-02 08:06:20 评论:0

mysql8.0 查看事务隔离级别报错

问题

数据库查看事务隔离级别

?
1 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

命令更改为

?
1 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事务开始时那一瞬间的数据快照;—幻读

串行化

不允许读写并发操作,写执行时,读必须等待;

四、数据库设置

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 //查看当前事物级别(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+ 查询数据库事务隔离级别

根据慕课网课程中的方法,查询事务隔离级别使用:

?
1 select @@tx_isolation;

我在sequal pro中,却提示错误:unknown system variable ‘tx_isolation'

查询了官方文档,在8.0+就已经抛弃了这样的查询方法,

https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html

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

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

1、select @@transaction_isolation;

2、show variables like ‘transaction_isolation';

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

原文链接:https://blog.csdn.net/qq_36957885/article/details/90743566

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容