我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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';

在这里插入图片描述

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何查看当前MySQL的事务隔离级别?

通过执行SELECT @@TX_ISOLATION命令我们可以检查当前MySQL事务隔离级别。示例mysql> SELECT @@TX_ISOLATION;+-----------------+| @@TX_ISOLATION |+
2023-10-22

MySQL查看和修改事务隔离级别的实例讲解

查看事务隔离级别 在 MySQL 中,可以通过show variables like '%tx_isolation%'或select @@tx_isolation;语句来查看当前事务隔离级别。 查看当前事务隔离级别的 SQL 语句和运行结果
2022-05-29

数据库事务隔离级别常见问题解答:帮你轻松理解数据库事务机制

数据库事务隔离级别是确保数据库事务正确执行的关键机制之一,它规定了不同事务并发执行时,对彼此可见的数据范围和影响。本文将深入探讨数据库事务隔离级别常见的问题,帮助您轻松理解数据库事务机制,确保数据一致性和完整性。
数据库事务隔离级别常见问题解答:帮你轻松理解数据库事务机制
2024-02-10

Go语言中如何处理并发数据库连接的事务隔离级别问题?

Go语言中如何处理并发数据库连接的事务隔离级别问题?随着大数据时代的到来,数据库操作已成为了程序开发中的重要环节。而在并发环境下,如何处理数据库连接的事务隔离级别问题成为了一个值得探讨的话题。本文将介绍如何使用Go语言来处理这个问题,并提供
2023-10-22

编程热搜

目录