zoukankan      html  css  js  c++  java
  • java 高并发 订单编号递增(解决方案)

    业务描述:

      首先从数据中查找最近的一条订单数据,然后将之前的订单号码+1作为新的订单号码,插入到数据库当中。(需求不能改变

      当出现并发操作时,A从数据库中获取最近一条订单的订单号为N,这是A还没有完成新订单的插入操作。B用户进来,也获取最近一条订单的订单号为N,这是A和B 想数据库同事插入的订单就有相同的订单号码。

    解决方法1:

      程序用同步锁控制(synchronized),性能急剧下降了,本身 java 就是多线程的,你把它单线程使用,不是明智的选择,同时,如果分布式部署的时候,加了 synchronized  也无法控制并发。

    解决方法2:

      redis 自增。将订单号自增字段,交给redis管理。

    解决方法3:

      乐观锁:(可能睡涉及到多次提交,用户体验性差)。

    解决方法4:

      数据库行锁:行锁的同时,可能会影响其他程序对数据库的操作。

    解决方式5:

      数据库(唯一性约束UNIQUE KEY),由于订单号不能重复,当插入相同的订单号码,就会产生错误。

  • 相关阅读:
    codova 打包vue项目的坑
    vscode 开发wtl 笔记
    redis
    展开/收缩 ul
    ueditor
    xml
    NPOI
    滚动效果,有些浏览器不支持
    fileupload控件上传、文件下载
    excel函数
  • 原文地址:https://www.cnblogs.com/chihirotan/p/6483890.html
Copyright © 2011-2022 走看看