mysql 事务隔离级别设置

本文介绍了SQL的事务隔离级别,包括session级别(如Readcommitted)的本地作用,global级别(root用户)的全局持久性,以及如何在MySQL配置和Spring框架中指定事务隔离级别,讨论了Repeatable与Readcommitted的区别及其对并发性能的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

查询隔离级别

select @@transaction_isolation;

session 级别

  • 只对当前打开的会话有效,比如一个navicat窗口
SET session TRANSACTION ISOLATION LEVEL Read committed (参数可以为:Read uncommittedRead committedRepeatableSerializable

global 级别 (root用户才行)

  • 全局有效,重启则无效
SET global TRANSACTION ISOLATION LEVEL Read committed

修改my.conf 默认隔离级别

  • 永久有效
  • mysql默认是Repeatable,高并发容易造成很多间隙锁,对于非严格事务的操作影响效率
[mysqld]
transaction-isolation=READ-COMMITTED

spring代码指定事务级别

	@Transactional(isolation = Isolation.READ_UNCOMMITTED)
    public void save(Demo demo) {
    	demoMapper.insert(demo);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乘茶蛙泳

just 4 fun

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值