[MySQL] 有没有解决幻读问题
程序员文章站
2022-04-15 16:17:51
默认隔离级别下 , mysql没有解决幻读问题 , 需要应用代码里加一个锁来解决 幻读问题是啥? 默认的隔离级别是可重复读 REPEATABLE-READ , 在这个模式下出现幻读的例子一般是这两种情况: 事务1和事务2同时 , 事务1读数据 , 事务2插入数据提交 , 事务1插入同样的数据时报错说 ......
默认隔离级别下 , mysql没有解决幻读问题 , 需要应用代码里加一个锁来解决
幻读问题是啥?
默认的隔离级别是可重复读 repeatable-read , 在这个模式下出现幻读的例子一般是这两种情况:
事务1和事务2同时 , 事务1读数据 , 事务2插入数据提交 , 事务1插入同样的数据时报错说已经重复了 , 我明明刚才查的时候没有 , 为啥报重复了?
事务1和事务2同时 , 事务1读数据 , 事务2插入数据提交 , 事务1更新数据可以把事务2的数据也一块给更了 , 明明刚才没有怎么突然多出来数据了?
解决方式是在select读时候的sql中增加for update , 会把我所查到的数据锁住 , 别的事务根本插不进去 , 这样就解决了,这里用到的是mysql的next-key locks
上一篇: python---协程 学习笔记
下一篇: 【随笔】开源之殇
推荐阅读
-
解决mysql时区与系统时区不一致问题。异常:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized o
-
解决Linux下Tomcat向MySQL插入数据中文乱码问题
-
解决Navicat Premium 连接 MySQL 8.0 报错"1251"的问题分析
-
Mac环境mysql5.7.21 utf8编码问题及解决方案
-
设置MySql5.5数据库的字符编码为UTF8,解决中文乱码问题_MySQL
-
MySQL 5安装过程中遇到的问题的解决
-
怎样解决MySQL数据库主从复制延迟的问题
-
myeclipse连接mysql数据库错误问题解决(搞了好久才发现是这个问
-
mysql问题及其解决办法_MySQL
-
关于MySQL时常闪退的问题解决办法分享(图)