高并发下怎样生成唯一的订单号?

开发 架构
一个软件系统,肯定到处充满着各种单据,也必然需要有各种单据号与之对应。比如:电商行业的订单号、支付流水号、退款单号等等。

[[408513]]

本文转载自微信公众号「UP技术控」,作者conan5566。转载本文请联系UP技术控公众号。

 一个软件系统,肯定到处充满着各种单据,也必然需要有各种单据号与之对应。比如:电商行业的订单号、支付流水号、退款单号等等。SCM的采购单号、进货单号、出货单号、盘点单号等。在一个企业内部或者一个2C的平台,无法避免的需要通过某个单据号来进行沟通。所以一个好的单据号必然是便于沟通的。那么如何创建全局唯一的单据号。

1、单系统使用object

  1. /// <summary> 
  2.    /// 单号助手 
  3.    /// </summary> 
  4.    public class BillNoHelper 
  5.    { 
  6.  
  7.        /// <summary> 
  8.        ///  防止创建类的实例 
  9.        /// </summary> 
  10.        private BillNoHelper() { } 
  11.        private static readonly object locker = new object(); 
  12.        private static int _sn = 0; 
  13.        /// <summary> 
  14.        /// 生成单据编号 
  15.        /// </summary> 
  16.        /// <returns></returns
  17.        public static string GenerateId() 
  18.        { 
  19.            lock (locker)   //lock 关键字可确保当一个线程位于代码的临界区时,另一个线程不会进入该临界区。 
  20.            { 
  21.                if (_sn == 9999) 
  22.                { 
  23.                    _sn = 1; 
  24.                } 
  25.                else 
  26.                { 
  27.                    _sn++; 
  28.                } 
  29.                return DateTime.Now.ToString("yyMMddHHmmss") + _sn.ToString().PadLeft(4, '0'); 
  30.            } 
  31.        } 
  32.        /// <summary> 
  33.        /// 唯一值 
  34.        /// </summary> 
  35.        /// <returns></returns
  36.        public static string guid() 
  37.        { 
  38.            return Guid.NewGuid().ToString().Replace("-"""); 
  39.        } 
  40.        /// <summary> 
  41.        /// GuidExtension 
  42.        /// </summary> 
  43.        /// <param name="guid"></param> 
  44.        /// <returns></returns
  45.        public static string IsNum(Guid guid) 
  46.        { 
  47.            var s = guid.ToString(); 
  48.            var sb = new StringBuilder(); 
  49.            for (int i = 0; i < s.Length; i++) 
  50.            { 
  51.                if (Char.IsNumber(s, i)) 
  52.                { 
  53.                    sb.Append(s.Substring(i, 1)); 
  54.                } 
  55.            } 
  56.            return sb.ToString(); 
  57.        } 
  58.  
  59.  
  60.        #region 生成 Coupon Key  
  61.        private static readonly object locker2 = new object(); 
  62.        private static int _sn2 = 0; 
  63.        /// <summary> 
  64.        /// 生成key 12位  字母+数字  
  65.        /// </summary> 
  66.        /// <returns></returns
  67.        public static string GenerateCouponKey()// 
  68.        { 
  69.            string s; 
  70.            lock (locker2) 
  71.            { 
  72.                if (_sn2 == 9999999) 
  73.                { 
  74.                    _sn2 = 1; 
  75.                } 
  76.                else 
  77.                { 
  78.                    _sn2++; 
  79.                } 
  80.                s = $"Qq@,.*745u787#$@,.><;'{DateTime.Now.Ticks}{_sn2}"
  81.            } 
  82.            return MD5_16(s); 
  83.  
  84.        } 
  85.        private static string MD5_16(string p_str) 
  86.        { 
  87.  
  88.            System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create(); 
  89.            byte[] data = System.Text.Encoding.Default.GetBytes(p_str); 
  90.            byte[] md5Data = md5.ComputeHash(data); 
  91.            string strResult = System.BitConverter.ToString(md5Data, 4, 8); 
  92.            md5.Clear(); 
  93.            strResult = strResult.Replace("-""").ToUpper(); 
  94.            return strResult; 
  95.        } 
  96.        #endregion 
  97.  
  98.    } 

2、数据唯一索引

利用数据库索引的特性生成唯一id.

3、使用redis分布式锁

在同一时间只会有一个客户端能获取到锁,其它客户端无法同时获取,这把锁在一段有限的时间之后,一定会被释放(正常释放或异常释放)。

 

责任编辑:武晓燕 来源: UP技术控
相关推荐

2024-10-14 12:05:56

2019-08-23 08:09:18

订单号生成数据库ID

2024-09-04 08:55:56

2019-08-15 11:11:38

Java数据库设计

2025-01-02 09:06:43

2020-10-21 12:10:30

订单号Java代码

2014-08-08 13:30:44

Nginx

2013-01-30 10:12:24

NginxNginx优化高并发

2021-12-28 06:55:09

事故订单号绩效

2024-10-31 09:04:20

Spring高并发

2024-08-06 08:13:26

2019-10-30 16:54:08

golangredis数据库

2022-06-12 06:45:26

高并发防重

2024-01-26 08:28:41

工单号生成器场景

2022-12-22 17:46:19

2023-02-03 15:16:42

SpringHystrix

2017-11-27 08:50:29

架构数据存储

2020-07-15 08:14:12

高并发

2019-11-08 08:40:29

Java高并发流量

2021-03-28 09:45:05

幂等性接口数据
点赞
收藏

51CTO技术栈公众号