Ralph Chen 2022-11-10 10:39 采纳率: 75%
浏览 27
已结题

Java多线程调用生成多条数据

场景:注册企业信息的时候根据企业的统一社会信用代码去查询数据库是否存在该企业,如果存在则更新,如果不存在则新增
问题:如果多线程同时调用接口,会导致新增多条相同数据

        CompanyInfoTemp companyInfoTemp1 = getListBuUniscId(uniscId);
        if(companyInfoTemp1==null){
            baseMapper.insert(companyInfoTemp);
        }else{
            companyInfoTemp.setCompanyId(companyInfoTemp1.getCompanyId());
            baseMapper.updateById(companyInfoTemp);
        }

期望结果:多线程调用时也只新增一条数据,其他为更新
已尝试过为该方法添加synchronized锁,可以实现,但效率会降低,期望得到一个其他方法

  • 写回答

2条回答 默认 最新

  • Silwings银翼 2022-11-10 10:51
    关注

    1.统一社会信用代码设置为唯一键
    2.不做判断直接insert
    3.尝试捕获唯一键异常,如果是统一社会信用代码的唯一键冲突就执行更新

    疑问:
    为啥已经存在的该企业,该企业还需要注册企业信息?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 於黾 2022-11-10 11:12
    关注

    接口这里如果不加锁,那就在数据库层面写个存储过程
    总之,既然你并行的两个请求可能互相冲突,那就必须让它们变成串行的
    你要是为了效率不顾错误,也可以并行往里面塞,然后每天定时启动个服务把所有多的删掉,根据时间保留新的删除旧的

    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月18日
  • 已采纳回答 11月10日
  • 修改了问题 11月10日
  • 创建了问题 11月10日

悬赏问题

  • ¥15 Tpad api账户 api口令
  • ¥30 ppt进度条制作,vba语言
  • ¥15 stc12c5a60s2单片机测光敏ADC
  • ¥15 生信simpleaffy包下载
  • ¥15 请教一下simulink中S函数相关问题
  • ¥15 在二层网络中,掩码存在包含关系即可通信
  • ¥15 端口转发器解析失败不知道电脑设置了啥
  • ¥15 Latex算法流程图行号自定义
  • ¥15 关于#python#的问题:我在自己的电脑上运行起来总是报错,希望能给我一个详细的教程,(开发工具-github)
  • ¥40 基于51单片机实现球赛计分器功能