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

來源:互聯網
上載者:User
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,'0',STR_PAD_LEFT);

第四種:

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

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

產生效果:

A422694333616096

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

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

相關推薦:

PHP 隨機數 C擴充隨機數

基於php 隨機數的深入理解_PHP教程

PHP產生UUID的正確姿勢是?

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.