Java防止相同数据重复提交方案

Java防止相同数据重复提交方案

场景

在开发工作中由于接口处理数据过慢,导致还没保存到数据库时再次提交相同的数据,此时数据库内没有这条数据出现了重复提交的脏数据

解决办法

1.前端控制提交未返回结果之前按钮禁用
document.getElementById("btn").disabled = true;
(无法避免恶意用户调用接口提交数据,所以前端卡死的办法不是特优)

2.在Java代码增加synchronized关键字使提交数据一条一条执行

public synchronized Result<?> save (Model model){ return null }

(使用起来比较简单但性能很低,在处理数据时会有排队等候的问题,并且在多实例部署时无法起到作用)

3.通过缓存或非关系型数据库比如Redis,Memcached将提交数据通过无法重复的key缓存起来在异步插入到数据库,因为关系型数据库时key,value形式的不会存相同的数据进去
(需要系统内有关系型数据库,没有的话集成进去为了防止重复插入代价太大)

4.通过数据库限制插入
在某个字段限制唯一约束

ALTER TABLE <TABLE> ADD unique(column);

(会有局限性,一般情况下都是多个字段同时相同)
设置联合唯一索引

ALTER TABLE <TABLE> ADD UNIQUE KEY(column,column);

(本人用的这种方法,在重复插入时sql会报异常,捕获异常后返回异常信息)

本人也是菜鸟一枚,如有错误还望指出,谢谢各位大牛

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java中,可以使用锁来防止重复提交。引用和引用展示了使用注解来实现锁的方法。通过在方法上添加相应的注解,可以实现对方法的加锁操作,从而避免重复提交的问题。这种方法可以在并发情况下有效地防止重复提交。 除了使用注解,还可以采用其他的方法来解决重复提交的问题。引用提供了一些解决方案。其中包括前端和后端的方案。前端方案可以通过前端的js控制提交按钮的状态,避免用户多次提交。后端方案可以在提交后重定向到其他页面,防止用户通过刷新或浏览器的前进后退按钮造成的重复提交。还可以在后端将唯一标识符放入表单、session或token中,在每次操作时校验标识符,避免重复处理相同的请求。另外,还可以使用数据结构如ConcurrentHashMap、LRUMap或Google Cache来存储唯一标识符,实现防止重复提交的功能。最后,可以使用Redis分布式锁来实现对请求的加锁操作,确保同一时间只有一个请求能够进行处理。 综上所述,Java可以使用锁来防止重复提交。可以通过注解、前端控制、后端标识符校验或Redis分布式锁等方法来实现。具体的实现方式可以根据具体的需求和场景选择。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [java开发中 防止重复提交的几种方案](https://blog.csdn.net/qq_33454058/article/details/125516310)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值