修改mysql的隔离级别

MySQL的隔离级别是指数据库事务的隔离程度,用于控制并发事务之间的相互影响。MySQL支持四种隔离级别,分别是读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。

  1. 读未提交(Read Uncommitted):最低的隔离级别,事务可以读取其他事务未提交的数据。这种隔离级别可能导致脏读(Dirty Read),即读取到未提交的数据。

  2. 读已提交(Read Committed):事务只能读取其他事务已经提交的数据。这种隔离级别可以避免脏读,但可能会导致不可重复读(Non-repeatable Read),即在同一个事务中多次读取同一数据时,可能会得到不同的结果。

  3. 可重复读(Repeatable Read):事务在执行期间保持一致的快照,即多次读取同一数据时,结果不会发生变化。这种隔离级别可以避免脏读和不可重复读,但可能会导致幻读(Phantom Read),即在同一个事务中多次查询同一范围的数据时,结果集合的行数可能会发生变化。

  4. 串行化(Serializable):最高的隔离级别,事务串行执行,避免了脏读、不可重复读和幻读。但由于串行执行的特性,可能会导致并发性能下降。

在实际应用中,可以根据业务需求选择合适的隔离级别。较低的隔离级别可以提高并发性能,但可能会导致数据不一致的问题;较高的隔离级别可以保证数据的一致性,但可能会降低并发性能。

要通过SQL命令修改MySQL数据库的默认隔离级别,并且使其永久生效,可以按照以下步骤进行操作:

  1. 进入MySQL容器的命令行界面,可以使用以下命令:

    复制代码
    docker exec -it <容器名称或ID> mysql -u<用户名> -p<密码>

    例如:docker exec -it mysql_container mysql -uroot -p

  2. 输入密码后,进入MySQL命令行界面。

  3. 使用以下命令查看当前的默认隔离级别:

    复制代码
    SELECT @@global.tx_isolation;
  4. 使用以下命令修改默认隔离级别,例如将隔离级别修改为"READ-COMMITTED":

    复制代码
    SET GLOBAL tx_isolation = 'READ-COMMITTED';
  5. 使用以下命令再次查看隔离级别,确认修改是否成功:

    复制代码
    SELECT @@global.tx_isolation;
  6. 退出MySQL命令行界面,输入以下命令退出容器的命令行界面:

    复制代码
    exit
  7. 重启MySQL容器,以使修改的默认隔离级别永久生效。

注意:以上操作只会修改当前MySQL容器的默认隔离级别,如果需要修改持久化存储的MySQL数据库的默认隔离级别,需要在启动容器时指定相应的配置参数或修改配置文件。

踩坑:在同一个事务里如果有更新,读取同一张表,必须把数据库的隔离级别设置为READ-COMMITTED, rr的隔离级别在同一个事务中是都读取不到上一条更新的内容的。

相关推荐
你想考研啊2 分钟前
mysql数据库导出导入
数据库·mysql·oracle
会Tk矩阵群控的小木15 分钟前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
十年编程老舅1 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 20231 小时前
Vue复习
linux·服务器·数据库
云边有个稻草人1 小时前
深度解析:KingbaseES高可用架构落地原理与生产运维实战
数据库·读写分离·数据库运维·金仓数据库·国产数据库技术·数据备份恢复
满天星83035772 小时前
【Qt】信号和槽(二) (自定义信号和槽)
开发语言·数据库·qt
我不介意孤独3 小时前
04-记忆系统为什么向量数据库不够用
数据库·人工智能·资源隔离·agent infra
AOwhisky3 小时前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算
qq21084629534 小时前
【数据库】TDengine 清理旧数据
数据库·oracle·tdengine
j_xxx404_4 小时前
MySQL表操作硬核解析:从 CREATE TABLE 到磁盘文件、ALTER TABLE 与 DDL 风险
运维·服务器·数据库·c++·mysql·adb·ai