首頁  >  文章  >  後端開發  >  php怎麼產生不重複的序號

php怎麼產生不重複的序號

藏色散人
藏色散人原創
2021-03-03 09:28:373145瀏覽

php產生不重複的序號的方法:1、透過「str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT);」方式產生不重複的序號;2、透過implode和array_map等函數實作會產生不重複的序號。

php怎麼產生不重複的序號

本文操作環境:windows7系統、PHP7.1版,DELL G3電腦。

PHP產生唯一不重複編號的方法總結

 

PHP如何產生唯一不重複編號?很多時候,例如訂單都需要我們產生唯一編號。在常規情況下,PHP提供的uniqid()能夠滿足需求,但是在高並發的時候,我們就需要更好的方案來產生唯一不重複編號。本文將分享實例程式碼,希望對大家有幫助。

 

前陣子有個電子商務項目,需要產生訂單號碼。當時的考慮很簡單,取系統時間加上隨機數,或使用 uniqid() 方法。仔細考慮下上述方法,在顧客購買量少的情況下,訂單重複的可能性為零,但是在購買高蜂期產生的訂單號重複是很有可能發生的。

第一種

return date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT);

第二種

return date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);

第三種

 

//生成24位唯一订单号码,格式:YYYY-MMDD-HHII-SS-NNNN,NNNN-CC,其中:YYYY=年份,MM=月份,DD=日期,HH=24格式小时,II=分,SS=秒,NNNNNNNN=随机数,CC=检查码
 @date_default_timezone_set("PRC");
 while(true){
  //订购日期
  $order_date = date('Y-m-d');
  //订单号码主体(YYYYMMDDHHIISSNNNNNNNN)
  $order_id_main = date('YmdHis') . rand(10000000,99999999);
  //订单号码主体长度
  $order_id_len = strlen($order_id_main);
  $order_id_sum = 0;
  for($i=0; $i<$order_id_len; $i++){
  $order_id_sum += (int)(substr($order_id_main,$i,1));
  }
  //唯一订单号码(YYYYMMDDHHIISSNNNNNNNNCC)
  $order_id = $order_id_main . str_pad((100 - $order_id_sum % 100) % 100,2,&#39;0&#39;,STR_PAD_LEFT);

 

第四種:

在網路上找了一番,發現這位同學的想法挺不錯的,redtamo,具體的請穩步過去看看,我作簡要概述,該方法用上了英文字母、年月日、Unix 時間戳記和微秒數、隨機數,重複的可能性大大降低,還是很不錯的。使用字母很有代表性,一個字母對應一個年份,總共16位,不多也不少,呵呵。

<?php
$yCode = array(&#39;A&#39;, &#39;B&#39;, &#39;C&#39;, &#39;D&#39;, &#39;E&#39;, &#39;F&#39;, &#39;G&#39;, &#39;H&#39;, &#39;I&#39;, &#39;J&#39;);
$orderSn = $yCode[intval(date(&#39;Y&#39;)) - 2011] . strtoupper(dechex(date(&#39;m&#39;))) . date(&#39;d&#39;) . substr(time(), -5) . substr(microtime(), 2, 5) . sprintf(&#39;%02d&#39;, rand(0, 99));
?>

 

產生效果:

A422694333616096

唉,不過很可惜,最後專案並沒有使用這種方法,說是沒必要搞這麼複雜, - -!

以上四種方法就是本文要跟大家分享的全部內容了,希望大家能夠喜歡。

【推薦:PHP影片教學

#

以上是php怎麼產生不重複的序號的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn