MySQL在可重复读的情况下,当一个线程去查询某条数据不存在在插入的情况下是不靠谱的,因为在开启事务到查询期间,有可能另一个线程已经插入了数据,而可重复读的情况下,单前事务是查询不到新插入的数据的,就会出现插入重复的情况,这时解决方法有:
1数据库加唯一索引
2在程序里使用分布式锁,程序拿到锁之后在执行查询,这时候的其他线程拿不到锁是不会插入的,所以这时候的查询时可靠的。
3在事务的查询用select …for update
mysql可重复读引发的问题
最新推荐文章于 2025-03-10 13:30:54 发布
在MySQL的可重复读隔离级别下,线程可能因在查询期间另一线程插入数据而导致插入重复。为避免这种情况,可以采取三种策略:1) 数据库字段添加唯一索引以防止重复;2) 在程序中使用分布式锁,确保查询的准确性;3) 使用`SELECT ... FOR UPDATE`来锁定行,确保事务内的查询可见性。
2595

被折叠的 条评论
为什么被折叠?



