概述
mysql数据库在高并发场景下重复插入如何保证唯一性解决方案
-
- 高并发场景
- 简单粗暴
- 前后端都做防重复操作
- mysql表加唯一索引
- 使用redis缓存
高并发场景
在高并发场景中,经常会遇到并发重复数据插入,没有唯一索引(比如有逻辑删除)却要保证唯一性的问题。比如分布式告警计算中,多个计算实例同时计算出同一个告警并同时插入相同的告警记录到数据库中,这时应该只插入一条记录。本文分析了在MySQL的InnoDB引擎中解决这类的问题的4种思路和相关方案。
简单粗暴
直接每条select, 判断,然后insert,毫无疑问,这是最笨的方法了,不断的查询判断,有主键或索引冲突,执行update,否则执行insert. 数据量稍微大一点这种方式就不行了。
前后端都做防重复操作
1、前端页面在表单提交后,把按钮置为disabled,短时间内不可重复点击提交数据
缺点:这种解决方案太依赖前端,并且无法保证刷新时重复提交表单
2、做表单防重复提交,在页面打开时,在session和页面中设置token,表单提交时判断token,并删除session中的token
缺点:目前的项目中没有先例,要解决防重复提
最后
以上就是爱笑发卡为你收集整理的mysql数据库在高并发场景下重复插入如何保证唯一性解决方案的全部内容,希望文章能够帮你解决mysql数据库在高并发场景下重复插入如何保证唯一性解决方案所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复