解决方案:如何防止数据重复插入?

  • 时间:
  • 浏览:1
  • 来源:大发pk10_pk10苹果app下载_大发pk10苹果app下载

摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢!

目录

  1. 为什么我么我要正确处理数据重复插入?
  2. 正确处理方案实战
  3. 可落地小总结

什么的大问题起源,微信小程序运行池池抽风 wx.request() 重复请求服务器提交数据。后端服务也很简单,伪代码如下:

class SignLogService {
    public void saveSignLog(SignLogDO log) {
        

发现数据库会处于重复数据行,提交时间一模一样。但业务需求是只有有多余的 log 突然总出 ,这明显是个什么的大问题。

什么的大问题是,重复请求导致 的数据重复插入。这什么的大问题造成的后果很明显:

  • 数据冗余,可是我不单单多每根
  • 可是我业务需求只有有多余数据,造成服务什么的大问题

什么的大问题如图所示:

正确处理法律土最好的办法:如可将 同请求 A,不执行插入,可是我 读取前好几个 多请求插入的数据并返回。正确处理后流程应该如下:

1.单库单表正确处理方案

  • 唯一索引 + 唯一字段
  • 幂等

里边说的那种业务场景:sign_log 表会有 user_id、sign_id、sign_time 等。那末 每次签到,每自己每天只有每根签到记录。

数据库层采取唯一索引的形式,保证数据记录唯一性。即 UNIQUE 约束,UNIQUE 约束唯一标识数据库表中的每条记录。另外,user_id,sign_id,sign_time 好几个 多组要花费唯一字段。创表的伪代码如下:

CREATE TABLE sign_log
(
id int NOT NULL,
user_id int NOT NULL,
sign_id int,
sign_time int,
CONSTRAINT unique_sign_log UNIQUE (user_id,sign_id,sign_time)
)

重点是 CONSTRAINT unique_sign_log UNIQUE (user_id,sign_id,sign_time)。有个小什么的大问题,数据量大的完后 ,每条记录还会有对应的唯一索引,比较耗资源。那末 曾经就行了吗?

答案是不行,服务不足英文健壮。第好几个 多请求插入成功,第好几个 请求直接报错,Java 服务会抛出 DuplicateKeyException 。

简单的幂等写法操作即可,伪代码如下:

class SignLogService {
    public SingLogDO saveSignLog(SignLogDO log) {
        

的确,流量否是很大,可是我 算很高并发。重复写什么的大问题,曾经正确处理即可。那大流量、高并发场景咋搞

2.分库分表正确处理方案

流量大了后,单库单表会演变成分库分表。那末 基于单表的唯一索引形式,在碰到分表就无法保证呢,插入的地方也否是好几个 多分表 A1 和 A2。

正确处理思路:将数据的唯一性条件贴到 可是我存储,并进行锁控制

还是里边的例子,每天,每次签到,每自己只有每根签到记录。那末 使用分布式锁 Redis 的正确处理方案。大致伪代码如下:

a.加锁

  • lockKey 最简单的是 user_id + sign_id + sign_time
  • expireTime 设置为一天

b.解锁

c.幂等代码加强

class SignLogService {
    public SingLogDO saveSignLog(SignLogDO log) {

        

這個方案还否是很成熟是什么期的句子的句子的句子是什么是什么的句子的句子 图片 ,大伙儿儿参考下即可。

正确处理方案实战中,了解具体术。归纳如下:

  • 幂等:保证多次同意请求后结果一致
  • 并发控制:单表唯一索引、分布式多表分布式锁
  • 降级兜底方案:分布式锁锁失效 – 考虑乐观锁兜底

参考资料

  • 重复插入方案: http://www.bysocket.com/archives/2266
  • 《阿里巴巴 Java 开发手册》

以下专题教程你说歌词 您会有兴趣

  • 《Spring Boot 2.x 系列教程》
  • 《Java 核心系列教程》

(关注微信公众号,领取 Java 精选干货学习资料)