电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL高并發生成唯一訂單號的方法實現

瀏覽:15日期:2023-10-05 15:56:12
前言

這篇博文發布后,有朋友問有沒有SQL server版本的,現在有了==》傳送門

一、場景再現

在一個erp進銷存系統或0A等其他系統中,如果多人同時進行生成訂單號的操作的話,容易出現多人獲得同一個訂單號的情況,對公司業務造成不可挽回的損失

二、如何避免高并發情況訂單號不唯一

我們可以利用存儲過程和數據表搭配,建立一張表和創建存儲過程,存儲過程負責生成訂單號,表負責處理唯一性問題

MySQL高并發生成唯一訂單號的方法實現

當存儲過程生成一個訂單編號,首先先把訂單號寫進表中,再把訂單號結果顯示出來,把生成的訂單號寫進表里會出現兩種情況,為什么呢?因為我們的表設置了主鍵(主鍵唯一性)

能寫進: 當表里沒有相同的訂單號,即把生成的訂單號寫進表里 不能寫進:當表里存在相同的訂單號,即生成的訂單號無法寫到表里,也就不能獲取到訂單號,從而確保高并發下生成唯一訂單號三、高并發情況下生成唯一訂單號的過程

下面將用代碼和實際操作講解下生成唯一訂單號的過程

第一步:建一張數據表,設置訂單號字段為主鍵(唯一訂單號的關鍵)

MySQL高并發生成唯一訂單號的方法實現

第二步:創建生成訂編號的存儲過程

生成訂單編號格式為:自定義前綴+年月日+后綴(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;四、運行結果

1.首先我的表里沒有數據,會生成前綴(我輸入的:UIE)+年月日(20200611)+001(第一個數據,所以是001)即:UIE20200611001

2當我第二次輸入時,由于表里有數據了,會根據最新的訂單編號后綴加1即:UIE20200611002

MySQL高并發生成唯一訂單號的方法實現

五、不是小結的小結

代碼下載鏈接:mysql_getbillno.sql

代碼截圖:

MySQL高并發生成唯一訂單號的方法實現

到此這篇關于MySQL高并發生成唯一訂單號的方法實現的文章就介紹到這了,更多相關MySQL高并發生成唯一訂單號內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 重庆私家花园设计-别墅花园-庭院-景观设计-重庆彩木园林建设有限公司 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | 碳纤维布-植筋胶-灌缝胶-固特嘉加固材料公司 | 超声波清洗机_超声波清洗机设备_超声波清洗机厂家_鼎泰恒胜 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 安徽免检低氮锅炉_合肥燃油锅炉_安徽蒸汽发生器_合肥燃气锅炉-合肥扬诺锅炉有限公司 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 啤酒设备-小型啤酒设备-啤酒厂设备-济南中酿机械设备有限公司 | 冷柜风机-冰柜电机-罩极电机-外转子风机-EC直流电机厂家-杭州金久电器有限公司 | 深圳希玛林顺潮眼科医院(官网)│深圳眼科医院│医保定点│香港希玛林顺潮眼科中心连锁品牌 | 大型果蔬切片机-水果冬瓜削皮机-洗菜机切菜机-肇庆市凤翔餐饮设备有限公司 | 瓶盖扭矩仪(扭力值检测)-百科 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 在线悬浮物浓度计-多参数水质在线检测仪-上海沃懋仪表科技有限公司 | 钢衬玻璃厂家,钢衬玻璃管道 -山东东兴扬防腐设备有限公司 | 周易算网-八字测算网 - 周易算网-宝宝起名取名测名字周易八字测算网 | 无缝方管|无缝矩形管|无缝方矩管|无锡方管厂家 | 山东臭氧发生器,臭氧发生器厂家-山东瑞华环保设备 | 飞象网 - 通信人每天必上的网站 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 钢化玻璃膜|手机钢化膜|钢化膜厂家|手机保护膜-【东莞市大象电子科技有限公司】 | 江西自考网-江西自学考试网| 首页-浙江橙树网络技术有限公司| 汕头市盛大文化传播有限公司,www.11400.cc | 江西高职单独招生-江西单招考试-江西高职单招网 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 无锡网站建设-做网站-建网站-网页设计制作-阿凡达建站公司 | 杭州营业执照代办-公司变更价格-许可证办理流程_杭州福道财务管理咨询有限公司 | 橡胶粉碎机_橡胶磨粉机_轮胎粉碎机_轮胎磨粉机-河南鼎聚重工机械制造有限公司 | 济南保安公司加盟挂靠-亮剑国际安保服务集团总部-山东保安公司|济南保安培训学校 | 集装袋吨袋生产厂家-噸袋廠傢-塑料编织袋-纸塑复合袋-二手吨袋-太空袋-曹县建烨包装 | 一级建造师培训_一建培训机构_中建云筑建造师培训网校 | 山东臭氧发生器,臭氧发生器厂家-山东瑞华环保设备 | 全自动包装秤_全自动上袋机_全自动套袋机_高位码垛机_全自动包装码垛系统生产线-三维汉界机器(山东)股份有限公司 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 阳光模拟试验箱_高低温试验箱_高低温冲击试验箱_快速温变试验箱|东莞市赛思检测设备有限公司 | U拓留学雅思一站式服务中心_留学申请_雅思托福培训 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 硬齿面减速机_厂家-山东安吉富传动设备股份有限公司 | 佛山市钱丰金属不锈钢蜂窝板定制厂家|不锈钢装饰线条|不锈钢屏风| 电梯装饰板|不锈钢蜂窝板不锈钢工艺板材厂家佛山市钱丰金属制品有限公司 | 扒渣机,铁水扒渣机,钢水扒渣机,铁水捞渣机,钢水捞渣机-烟台盛利达工程技术有限公司 |