文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mybatis高并发情况下防止重复插入记录的方法

2023-09-07 11:39

关注

一般的防止重复插入记录方法,是设立主键,或者唯一主键来控制,但是如果主键和唯一主键都不能控制的情况下要如何处理呢?

比如我们创建用户购买票券表

tbl_ticket_rec

字段

描述

id

自增主键

phone

手机号

ticket_id

票券id

return

是否退票--1 退票 0未退

time

买票时间

需求描述

一个手机号,表示一个用户,一个用户一个票id只能购买一次,但是当用户退票时,则可以再次购买,用户可以退票多次,也可以重复购买多次

需求分析

目前该表主键只有id做为自增主键,如果在高并发的情况下控制插入,那么就需要要每次插入时先查看一下库中是否存在该用户购票记录

select 1 from tbl_ticket_rec where phone = xx and return =0

如果库中不在存在购买且未退的记录,则可以插入库中。

但是在高并发的情况下,当我们从select 到 insert 过程中,可能存在其它线程入库的结果,导致select 结果不准确

方案改进:

这时候就需要调整一下select机制

inset into tbl_ticket_rec(phone,ticket,return) select '13700000000','0001','00' from dual where not exists (select 1 from tbl_ticket_rec where phone ='13700000000' and return ='0')

其中dual 是一张虚拟表

那么其对应的mapper文件,如以如下编写

insert into tbl_ticket_rec

phone,

ticket_id,

return,

select

#{phone,jdbcType=CHAR},

#{ticketId,jdbcType=CHAR},

#{return,jdbcType=CHAR},

from dual where not exists (select 1 from tbl_ticket_rec where #{phone,jdbcType=CHAR} and return = #{return,jdbcType=CHAR})

结论:

通过以上改进,可能有效的控制高并发情况下的数据入库重复问题

来源地址:https://blog.csdn.net/shenshiheng2006/article/details/128726715

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯