Android --- 订单编号怎样不重复?一秒钟如果有n个人同时下单怎么解决?凌晨12点限量抢购1000件商品,直到抢完为止订单编号怎么处理?
今天在做項(xiàng)目的時(shí)候發(fā)現(xiàn)了這個(gè)問(wèn)題,在我下單的時(shí)候,我是采用獲取年月日時(shí)分秒的方式來(lái)生成訂單編號(hào),但是這種方式行不通,如果一秒鐘有多個(gè)人下單的話,直接就會(huì)爆掉,比如:淘寶雙十一,凌晨12點(diǎn)限量搶購(gòu)1000件商品,直到搶完為止,那么就可定不可避免一秒鐘下多個(gè)訂單,所以我的解決辦法是:
在你生成訂單編號(hào)的工具類中定義一個(gè)靜態(tài)變量
private static int autoInt = 1;在你生成訂單編號(hào)的位置將 autoInt 加 1 再拼接到訂單編號(hào)的末尾 ,這樣的話,你每調(diào)用一次生成訂單編號(hào),就會(huì)加 1
// 生成不重復(fù)的訂單編號(hào)public static String getOrder() {SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmSS");Date date = new Date();autoInt++;String s = simpleDateFormat.format(date) + autoInt;System.out.println("訂單編號(hào)為:"+s);return s;}比如我本來(lái)的訂單編號(hào)是:20211119180797
調(diào)用了這個(gè)方法后就變成了 202111191807972
再次調(diào)用就變成了 202111191807973,以此類推
以上方法是我想到的不用去對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作的方法,本人使用 mysql 數(shù)據(jù)庫(kù),你也可以使用其他方法如**主鍵自增序列**,這個(gè)對(duì)于 mysql 比較難弄,對(duì)于 oracle 比較容易。
這里再說(shuō)一下, java 靜態(tài)變量,在服務(wù)器重新啟動(dòng)的時(shí)候就會(huì)恢復(fù)默認(rèn)值,這個(gè)不用擔(dān)心,因?yàn)?#xff0c;我們的時(shí)間戳是不斷變化的,所以即使恢復(fù)到 1 也不會(huì)重復(fù)
總結(jié)
以上是生活随笔為你收集整理的Android --- 订单编号怎样不重复?一秒钟如果有n个人同时下单怎么解决?凌晨12点限量抢购1000件商品,直到抢完为止订单编号怎么处理?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Android --- 按钮控件设置与不
- 下一篇: android sina oauth2.