H5W3
当前位置:H5W3 > 其他技术问题 > 正文

mysql 怎么防止重复插入呢

使用 unique key 可以保证

但是不使用唯一 key 的情况并且在并发提交的情况下怎么防止重复插入呢?

比如浏览器卡了一下,导致用户重复点击提交了

回答:

无非是利用唯一键或主键让数据库帮你解决,或者你自己插入之间写个逻辑判断来解决。

回答:

业务简单的话,建另外一张表做锁吧

回答:

你这种情况应该用业务代码控制,可以参考thinkphp的表单令牌:
打开表单页的时候生成一个token值,用session缓存起来,表单里也加一个隐藏域存放这个token,提交时发现这个token重复验证的话就报错。

回答:

可以用乐观锁或者悲观锁
乐观锁就是加一个version,插入前先查询version,插入时加一个条件where version = #{version} 算是cas的一种实现;
悲观锁,数据库提供的锁,插入前先对记录加锁,select * from table for update
两种方法乐观锁效率会高一些

回答:

1.前端控制,防止按钮重复提交
2.数据库加唯一索引 create unique index 索引名 on 表名 (字段名);

回答:

单机可以用缓存,把这次请求具有唯一性的参数缓存一下,缓存时长自己定。
当请求来了先判断这个请求的唯一性参数是否在缓存中,如果在的话就认为这是同一个请求,我们就把这个请求拒绝掉。

然后分布式可以把缓存放在redis上。

回答:

  • 前后端做限制防止同一表单多次提交,对于并发导致的这个限制就没什么用了。
  • 唯一字段数据如果可以提前生成的话,可以先生成批量数据存到redis中,SQL插入时直接查redis。
  • 或加唯一索引,写事务。

本文地址:H5W3 » mysql 怎么防止重复插入呢

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址