mysql可重复读引发的问题

在MySQL的可重复读隔离级别下,线程可能因在查询期间另一线程插入数据而导致插入重复。为避免这种情况,可以采取三种策略:1) 数据库字段添加唯一索引以防止重复;2) 在程序中使用分布式锁,确保查询的准确性;3) 使用`SELECT ... FOR UPDATE`来锁定行,确保事务内的查询可见性。

MySQL在可重复读的情况下,当一个线程去查询某条数据不存在在插入的情况下是不靠谱的,因为在开启事务到查询期间,有可能另一个线程已经插入了数据,而可重复读的情况下,单前事务是查询不到新插入的数据的,就会出现插入重复的情况,这时解决方法有:
1数据库加唯一索引
2在程序里使用分布式锁,程序拿到锁之后在执行查询,这时候的其他线程拿不到锁是不会插入的,所以这时候的查询时可靠的。
3在事务的查询用select …for update

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值