返回顶部
首页 > 资讯 > 数据库 >MySQL高并发生成唯一订单号的方法实现
  • 483
分享到

MySQL高并发生成唯一订单号的方法实现

MySQL高并发生成唯一订单号MySQL生成唯一订单号 2022-05-18 07:05:29 483人浏览 独家记忆
摘要

前言 这篇博文发布后,有朋友问有没有SQL server版本的,现在有了==》传送门 一、场景再现 在一个erp进销存系统或0A等其他系统中,如果多人同时进行生成订单号的操作的话,容易出现多人获得同一个订单号的情况,

前言

这篇博文发布后,有朋友问有没有SQL server版本的,现在有了==》传送门

一、场景再现

在一个erp进销存系统或0A等其他系统中,如果多人同时进行生成订单号的操作的话,容易出现多人获得同一个订单号的情况,对公司业务造成不可挽回的损失

二、如何避免高并发情况订单号不唯一

我们可以利用存储过程和数据表搭配,建立一张表和创建存储过程,存储过程负责生成订单号,表负责处理唯一性问题

在这里插入图片描述

当存储过程生成一个订单编号,首先先把订单号写进表中,再把订单号结果显示出来,把生成的订单号写进表里会出现两种情况,为什么呢?因为我们的表设置了主键(主键唯一性)

  • 能写进: 当表里没有相同的订单号,即把生成的订单号写进表里
  • 不能写进:当表里存在相同的订单号,即生成的订单号无法写到表里,也就不能获取到订单号,从而确保高并发下生成唯一订单号

三、高并发情况下生成唯一订单号的过程

下面将用代码和实际操作讲解下生成唯一订单号的过程

第一步:建一张数据表,设置订单号字段为主键(唯一订单号的关键)

在这里插入图片描述

第二步:创建生成订编号的存储过程

生成订单编号格式为:自定义前缀+年月日+后缀(001、002、003)
1.首先创建一个存储过程
输入为BILL_TYPE(前缀),输出为BILL_NOP(订单编号)


CREATE DEFINER = CURRENT_USER PROCEDURE `getbillno`(in BILL_TYPE VARCHAR(3), out BILL_NOP varchar(25))
BEGIN 

2.生成年月日和后缀
年月日为当前系统时间,后缀初始值为0


DECLARE currentDate varCHAR (15);
DECLARE lastno INT DEFAULT 0;
SELECT DATE_FORMAT(NOW(), '%Y%m%d') INTO currentDate;

3.查询表格,获取表格的订单编号
查询表格,获取前缀与自定义内容相关的最新一个订单编号


SELECT IFNULL(BILL_NO, 'notnull') INTO BILL_NOP
 FROM temp_bill 
 WHERE SUBSTRING(BILL_NO,1,3) =BILL_TYPE and
 SUBSTRING(BILL_NO,4,8) =currentDate
 ORDER BY BILL_NO DESC LIMIT 1;

4.生成订单编号

如果上一步获取的订单编号不为空,新生成的订单号在原订单号上+1

例:获取的订单号:UIE20200611015
即生成的订单号为:UIE20200611016

如果上一步获取的订单号为空,新生成的订单号后缀为001
例:生成的订单号:UIE20200611001


IF BILL_NOP !='' THEN
 SET lastno = CONVERT(SUBSTRING(BILL_NOP, -3), DECIMAL) ; 
 SELECT 
 CONCAT(BILL_TYPE,currentDate,LPAD((lastno + 1),3, '0')) INTO BILL_NOP ;
ELSE
 SELECT 
 CONCAT(BILL_TYPE,currentDate,LPAD((lastno + 1),3, '0')) INTO BILL_NOP ;
END IF;

5.将生成的订单号插入表中
如果表中存在相同订单号则插入表失败
如果表中不存在相同订单号则插入表成功


INSERT INTO temp_bill (BILL_NO, BILL_TYPE) VALUES (BILL_NOP,BILL_TYPE) ;

6.返回唯一订单编号
当订单插入表成功,即可返回唯一的订单编号(如果上一步不成功,即不会运行这一步)


SELECT BILL_NOP;

四、运行结果

首先我的表里没有数据,会生成前缀(我输入的:UIE)+年月日(
20200611)+001(第一个数据,所以是001)
即:UIE20200611001

2当我第二次输入时,由于表里有数据了,会根据最新的订单编号后缀加1
即:UIE20200611002

在这里插入图片描述

五、不是小结的小结

代码下载链接:Mysql_getbillno.sql

代码截图:

在这里插入图片描述

到此这篇关于mysql高并发生成唯一订单号的方法实现的文章就介绍到这了,更多相关MySQL高并发生成唯一订单号内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL高并发生成唯一订单号的方法实现

本文链接: https://lsjlt.com/news/10157.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL高并发生成唯一订单号的方法实现
    前言 这篇博文发布后,有朋友问有没有SQL server版本的,现在有了==》传送门 一、场景再现 在一个erp进销存系统或0A等其他系统中,如果多人同时进行生成订单号的操作的话,容易出现多人获得同一个订单号的情况,...
    99+
    2022-05-18
    MySQL高并发生成唯一订单号 MySQL 生成唯一订单号
  • MySQL高并发生成唯一订单号的方法是什么
    这篇文章主要介绍了MySQL高并发生成唯一订单号的方法是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。一、场景再现在一个erp进销存系统或0...
    99+
    2024-04-02
  • SQL server高并发生成唯一订单号的案例
    这篇文章给大家分享的是有关SQL server高并发生成唯一订单号的案例的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、场景再现在一个erp进销存系统或0A等其他系统中,如果多...
    99+
    2024-04-02
  • java web在高并发和分布式下实现订单号生成唯一的解决方案
    方案一:如果没有并发,订单号只在一个线程内产生,那么由于程序是顺序执行的,不同订单的生成时间戳正常不同,因此用时间戳+随机数(或自增数)就可以区分各个订单。如果存在并发,且订单号是由一个进程中的多个线程产生的,那么只要把线程ID添加到序列号...
    99+
    2023-05-30
    java web 高并发
  • JAVA生成唯一订单编号方案(两种方式)
    方法一:使用UUID public static String getUUID() { String replaceUUID = UUID.randomUUID().toString().replace("-", ""); ...
    99+
    2023-09-12
    java 开发语言
  • 高并发php uniqid不重复唯一标识符生成方案
    PHP uniqid()函数可用于生成不重复的唯一标识符,该函数基于微秒级当前时间戳。在高并发或者间隔时长极短(如循环代码)的情况下,会出现大量重复数据。即使使用了第二个参数,也会重...
    99+
    2024-04-02
  • Redis生成全局唯一ID的实现方法
    目录简介:特性:生成规则: ID生成类:测试类:简介: 全局唯一ID生成器是一种在分布式系统下用来生成全局唯一ID的工具 特性: 唯一性高性能安全性高可用递增性 生成规则:...
    99+
    2024-04-02
  • springboot集成redis并生成全局唯一索引ID的方法
    本篇内容主要讲解“springboot集成redis并生成全局唯一索引ID的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot集成redis并生成全局唯一索引ID的方法”吧!...
    99+
    2023-06-29
  • Go实现分布式唯一ID的生成之雪花算法
    目录背景:特性:雪花算法:分布式唯一ID的生成 背景: 在分布式架构下,唯一序列号生成是我们在设计一个尤其是数据库使用分库分表的时候会常见的一个问题 特性: 全局唯一,这是基本要求,...
    99+
    2024-04-02
  • 异步协程开发技巧:实现高并发的短链接生成器
    异步协程开发技巧:实现高并发的短链接生成器随着互联网的不断发展,越来越多的网页、应用程序和电子邮件等资源需要通过链接来进行分享和访问。长链接通常会造成阅读和复制的不便,而短链接则可以解决这个问题,使得链接更加简洁。为了满足大量用户同时生成短...
    99+
    2023-12-09
    异步 协程 高并发
  • nginx+lua单机上万并发的实现方法
    小编给大家分享一下nginx+lua单机上万并发的实现方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!nginx是我们最常用的服务器,常用于做内容分发和反向代理...
    99+
    2023-06-15
  • Java生成序号】实现自动编号的方法及代码详解
    Java生成序号】实现自动编号的方法及代码详解 在Java编程中,生成序号是一项常见的需求,无论是用于数据标识、列表展示还是生成唯一的标识符。本文将介绍如何使用Java语言实现自动编号的功能,并提供详...
    99+
    2023-10-22
    java 开发语言 Java
  • PHP细数实现提高并发能力的方法
    本篇文章给大家带来了关于PHP的相关知识,主要介绍了PHP提高并发能力有哪些方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面一起来看依稀啊,希望对大家有帮助。(推荐教程:PHP视频教程)本文已收录编程学...
    99+
    2022-08-18
    php
  • redis队列实现高并发的方法是什么
    在Redis中实现高并发的队列,可以使用Redis的list数据结构来实现队列的功能。具体步骤如下: 使用LPUSH命令将数据推...
    99+
    2024-04-09
    redis
  • Python使用tablib生成excel文件的简单实现方法
    本文实例讲述了Python使用tablib生成excel文件的方法。分享给大家供大家参考,具体如下: import tablib headers = ('lie1', 'lie2', 'lie3', '...
    99+
    2022-06-04
    简单 文件 方法
  • Android实现二维码扫描和生成的简单方法
    这里简单介绍一下ZXing库。ZXing是一个开放源码的,用Java实现的多种格式的1D/2D条码图像处理库,它包含了联系到其他语言的端口。Zxing可以实现使用手机的内置的摄...
    99+
    2022-06-06
    二维码扫描 方法 二维 二维码 Android
  • python实现mysql的单引号字符串过滤方法
    本文实例讲述了python实现mysql的单引号字符串过滤方法。分享给大家供大家参考,具体如下: 最主要用这个函数,可以处理MySQLdb.escape_string(content). class G...
    99+
    2022-06-04
    字符串 单引号 方法
  • Ecshop实现支付时传送商品订单号和商品名称的方法
    本文实例讲述了Ecshop实现支付时传送商品订单号和商品名称的方法。分享给大家供大家参考,具体如下: ecshop支付时传送商品订单号和商品名称,支付传递商品名称到支付平台 ecshop paypal付款如何传商品名称,...
    99+
    2022-06-12
    Ecshop 支付 传送 商品订单号 商品名称
  • vue生成二维码QR Code的简单实现方法示例
    目录qrcodejs2vue-qrqrcodejs2 下载qrcodejs2 cnpm i -S qrcodejs2 使用 <template> <span...
    99+
    2024-04-02
  • JAVA递归生成树形菜单的实现方法是什么
    今天小编给大家分享一下JAVA递归生成树形菜单的实现方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。  递归生成一个...
    99+
    2023-06-26
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作