支付不重复订单号生成

14 篇文章 0 订阅
1 篇文章 0 订阅

最近的项目中支付的订单号是使用附加项目中的工具做的,是一种带数据库自增形式的订单号,开始测试的时候没有任何问题,但是再高并发的实际应用中还是有不小的问题,只怪自己考虑太少,必须在高并发模式下保证订单号的唯一,我也参考了很多的案例,网上有个网友的回复很是精辟:

如果没有并发,订单号只在一个线程内产生,那么由于程序是顺序执行的,不同订单的生成时间一定不同,因此用时间就可以区分各个订单。

如果存在并发,且订单号是由一个进程中的多个线程产生的,那么只要把线程ID添加到序列号中就可以保证订单号唯一。

如果存在并发,且订单号是由同一台主机中的多个进程产生的,那么只要把进程ID添加到序列号中就可以保证订单号唯一。

如果存在并发,且订单号是由不同台主机产生的,那么MAC地址、IP地址或CPU序列号等能够区分主机的号码添加到序列号中就可以保证订单号唯一。

地址:https://www.oschina.net/question/1757031_2137794

还有种方法是再订单号中加入时间,用户id(或唯一标识),随机数:其实这种方法对于那种业务并发低一些的项目中,这不失为一种好并发,像我最近做的停车项目中用户就不会再同一时间内停多辆车,这不失为一种办法

我做的是

    /**
	 * 获得唯一订单号
	 */
	public static String getUniqueOrder() {
		 SimpleDateFormat format = new SimpleDateFormat("YYYYMMddHHmmss");
		 String format2 = format.format(new Date());
		 int hashCodeV = UUID.randomUUID().toString().hashCode();  
		 if(hashCodeV < 0) {
			//有可能是负数
			 hashCodeV = - hashCodeV;  
		 }
		 return "pk"+format2+String.format("%012d", hashCodeV);  
	}

以后做到多做笔记,记录下项目中遇到的点点滴滴

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值