修改mysql隔离级别_修改MySQL的事务隔离级别

SQL 标准的事务隔离级别包括:读未提交(read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(serializable )。

读未提交:一个事务还没提交时,它做的变更就能被别的事务看到。

读 提 交:一个事务提交之后,它做的变更才会被其他事务看到。

可重复读:一个事务执行过程中看到的数据,总是跟这个事务在启动时看到的数据是一致的。当然在可重复读隔离级别下,未提交变更对其他事务也是不可见的。

串 行 化:顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行。

你可以用SET TRANSACTION语句改变单个会话或者所有新进连接的隔离级别。它的语法如下:

如果出现权限相关问题请自行解决,我都是使用的高权限账号。

SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}

举例:设置全局为 可重复读(REPEATABLE READ),当前连接为串行化(SERIALIZABLE)

mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL REPEATABLE READ;

Query OK, 0 rows affected (0.04 sec)

mysql> SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;

Query OK, 0 rows affected (0.11 sec)

mysql> SELECT @@global.tx_isolation; #查询全局隔离级别

+-----------------------+

| @@global.tx_isolation |

+-----------------------+

| REPEATABLE-READ |

+-----------------------+

1 row in set, 1 warning (0.07 sec)

mysql> SELECT @@session.tx_isolation; #查询当前session隔离级别

+------------------------+

| @@session.tx_isolation |

+------------------------+

| SERIALIZABLE |

+------------------------+

1 row in set, 1 warning (0.06 sec)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值