幻读:指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次查询没有看到的数据行。(新增)
innodb 默认是可重复读隔离级别
在可重复读隔离级别下,普通的传是快照读,是不会看到别的事务插入的数据。只有幻读才能看到
幻读专指“新插入的行”
幻读引发的问题:(1)语义有问题.(2)数据不一致性
如何解决幻读,innodb引入了间隙锁,它加了7个间隙锁,防止新数据插入。一般无特殊说明都是左闭区间,右开区间,即前开后闭
除此之外也可以把隔离级别改为读提交,同时配合binlog_format=row来进行组合使用。
查看当前库使用的隔离级别:select @@tx_isolation;
本文来自博客园,作者:孙龙-程序员,转载请注明原文链接:https://www.cnblogs.com/sunlong88/p/13031094.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
2019-06-02 golang变量-数据类型一