为了账号安全,请及时绑定邮箱和手机立即绑定

mysql 怎么防止重复插入呢

mysql 怎么防止重复插入呢

白板的微信 2019-04-26 13:19:50
使用 unique key 可以保证但是不使用唯一 key 的情况并且在并发提交的情况下怎么防止重复插入呢?比如浏览器卡了一下,导致用户重复点击提交了
查看完整描述

7 回答

?
暮色呼如

TA贡献1853条经验 获得超9个赞

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


查看完整回答
反对 回复 2019-05-19
?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

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

查看完整回答
反对 回复 2019-05-19
?
撒科打诨

TA贡献1934条经验 获得超2个赞

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

查看完整回答
反对 回复 2019-05-19
?
SMILET

TA贡献1796条经验 获得超4个赞

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

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


查看完整回答
反对 回复 2019-05-19
  • 7 回答
  • 0 关注
  • 710 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号