订单号的生成

订单号有3个属性:1.唯一性 2.不可推测性 3.效率性

唯一性是当中最重要的一个,重复了这个订单号就没有意义。其次就是效率性,反复查找数据库会生成的很慢!

不规则订单号生成思路:System.currentTimeMillis()+几位随机数,就OK了。System.currentTimeMillis()这个数一般是不会出现同一个的。

在一些公司的内部系统中可能会要求我们给出一个规则的顺序订单号,比如:年月日+(当前订单数+1),特殊字符串+(当前订单数+1)。因为两个人同时操作时会是同一个订单号,那么为了保证订单号的唯一性,就不能通过查询数据库来找当前订单数(很有可能两个用户在同一时段查数据库,那就是同一个订单啦,没用!)。So,在数据中单独建立一个表来造一个当前订单数(CurrentIndentNum),初始值为0.

具体的数据库的设计:IndentTB:

IndentID

Indent

CurrentTime 初始值设定为getdate()

IfUse

CurrentIndentNumTB:

CurrentIndentNumID

CurrentIndentNum

在数据库存储过程中用:

update CurrentIndentNumTB

begin tran

set CurrentIndentNum=CurrentIndentNum+1

select CurrentIndentNum

from CurrentIndentNumTB

commit tran

(begin tran.... commit tran当事务出现异常,回滚到执行事务之前)

来保证订单的唯一性。

具体实施:在load事件或$(document).ready 中执行上述过程返回当前订单数到页面。如果取消订单,则标记ifuse为false。

时间: 2024-11-07 18:46:17

订单号的生成的相关文章

生成订单号 、生成优惠券号 前四位大写字母 后六位数字

// 生成订单号 public static String setRandomChar() { String str = ""; for (int i = 0; i < 10; i++) { int ch = (int) (10 * (Math.random())); str = str + ch; } return str; } // 生成优惠券号 前四位大写字母 后六位数字 public static String genCouponCode() { String str =

C# 订单号的生成

/**        * 根据当前系统时间加随机序列来生成订单号         * @return 订单号        */        public static string GenerateOrderNo()        {            Random ran = new Random();            return string.Format("{0}{1}{2}", "用户id", DateTime.Now.ToString(&q

简易发号SQL,可用于生成指定前缀自增序列,如订单号,生成优惠券码等

需求1:订单号要求唯一.长度不太长.自增.但不能通过早上订单号和晚上订单号相减推算出平台大概一天的单量 需求2:要求生成10w张优惠券,要求券码唯一.不能太长,不能轻易猜测出其他券码 根据这些需求提供一个简单的数据库发号的sql来满足上面的需求,介绍如下 Increments表设计两个字段,Prefix和MaxNum,不需要设计主键和聚集索引,在Prefix上建立唯一索引,可Include[MaxNum]字段,这样查询时可以保证索引覆盖 将前缀和数据拼接的服务由应用来提供,数据库自负责拿到增加后

订单号生成规则

前阵子,公司有个电子商务项目,需要生成订单号.当时的考虑很简单,取系统时间加上随机数,或者使用 uniqid() 方法.我们都知道,订单号最基本的要求就是唯一,这个条件必须满足.仔细考虑下上述方法,在顾客购买量少的情况下,订单重复的可能性为零,但是在购买高蜂期生成的订单号重复是很有可能发生的.所以上述方法不可靠,有待强化.在网上找了一番,发现这位同学的想法挺不错的,redtamo,具体的请稳步过去看看,我作简要概述,该方法用上了英文字母.年月日.Unix 时间戳和微秒数.随机数,重复的可能性大大

Thinkphp 生成订单号小案例

Thinkphp 生成订单号小案例小伙伴们在日常的商城项目开发中,都会遇到订单号生成的问题,今天呢思梦PHP就带领大家去解读一下生成订单号的问题!首先,订单号我们要明确它有有3个性质:1.唯一性 2.不可推测性 3.效率性,唯一性和不可推测性不用说了,效率性是指不能频繁的去数据库查询以避免重复.况且满足这些条件的同时订单号还要足够的短.不知道小伙伴们在日常的项目中是否也和我一样去思考过生成订单的一些小问题,可能你也会说,这些东西不用想的那么复杂,其实呢,小编也是同意大家的看法,但是殊不知我们做程

生成订单号

生成订单号,最大的问题是要考虑高并发的时候.在网上找的一些方案往往在这种情况下难以适用,比如,查询订单序列最大数,根据系统时间生成等. 再考虑另一种可行的方案:数据库递增序列,没错,确实能解决高并发的问题,但在集群等情况下对数据库压力比较大,而且有些数据库对递增序列没有很好的支持,同时递增序列的位数是一直增加的,也有可能会超出数据库表字段限制. 最好的方案是用java的uuid工具类生成唯一的字符串,然后再取这个字符串对象的hashcode值,因为字符串的值是唯一的,它的hashcode也是唯一

php生成唯一订单号

支持更改长度/** * 生成唯一订单号 * */ function build_order_no(){ return date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8); }

不重复订单号生成规则

偶尔在网上看到的,相对比较好的c#端订单号生成规则 public class BillNumberBuilder{ private static object locker = new object(); private static int sn = 0; public static string NextBillNumber(){ lock(locker){ if(sn == 9999999999) sn = 0; else sn++; return DateTime.Now.ToStrin

C#:lock锁与订单号(或交易号)的生成

1.新建项目(控制台应用程序) 2.新建一个类:OrderIdHelper.cs 1 /// <summary> 2 /// 订单助手 3 /// </summary> 4 class OrderIdHelper 5 { 6 private static readonly object Locker = new object(); 7 private static string _tempId = ""; 8 9 /// <summary> 10 /