首頁  >  文章  >  後端開發  >  php 根據自增id建立唯一編號類別的方法

php 根據自增id建立唯一編號類別的方法

墨辰丷
墨辰丷原創
2018-05-24 10:10:481470瀏覽

本文主要介紹了php根據自增id創建唯一編號類別的相關知識。具有很好的參考價值。以下跟著小編一起來看下吧

在開發過程中,我們資料表一般都會使用自增數字作為id主鍵,而id是數字型,不容易理解。我們把id依照一定格式轉為編號後,很容易根據編號知道代表的是什麼內容。

例如訂單表id=20160111197681234#,只看id我們不知道這個id是訂單表的id,而轉為編號# O-20160111197681234,則很容易看出是訂單表的記錄,然後可以根據id在訂單表中搜尋。

編號所建立的規則

1.唯一

##使用自增id生成,保證唯一性

2.盡可能短

#可使用數字求餘對應字母的方式處理,建立較短的編號

演算法原理

1.加上自訂前綴,用於識別

#2.格式使用前綴+字母+數字組成,數字只保留N位,超過的使用數字求餘的方式使用字母對應

例如:

id =1

前綴=F

數字保留3位元

則建立的編號為:

F-A-001

程式碼如下:

IDCode.class.PHP

<?php
/**
 * php 根据自增id创建唯一编号类
 * Date:  2016-11-27
 * Author: fdipzone
 * Ver:   1.0
 *
 * Func
 * Public create 创建编号
 */
class IDCode{ // class start
  /**
   * 创建编号
   * @param Int  $id     自增id
   * @param Int  $num_length 数字最大位数
   * @param String $prefix   前缀
   * @return String
   */
  public static function create($id, $num_length, $prefix){
    // 基数
    $base = pow(10, $num_length);
    // 生成字母部分
    $pision = (int)($id/$base);
    $word = &#39;&#39;;
    while($pision){
      $tmp = fmod($pision, 26); // 只使用26个大写字母
      $tmp = chr($tmp + 65);   // 转为字母
      $word .= $tmp;
      $pision = floor($pision/26);
    }
    if($word==&#39;&#39;){
      $word = chr(65);
    }
    // 生成数字部分
    $mod = $id % $base;
    $digital = str_pad($mod, $num_length, 0, STR_PAD_LEFT);
    $code = sprintf(&#39;%s-%s-%s&#39;, $prefix, $word, $digital);
    return $code;
  }
} // class end
?>



##demo.php

<?php
require &#39;IDCode.class.php&#39;;
$test_ids = array(1,9,10,99,100,999,1000,1009,2099,3999,9999,14999,99999);
foreach($test_ids as $test_id){
  echo $test_id.&#39; = &#39;.IDCode::create($test_id, 3, &#39;F&#39;).&#39;<br>&#39;;
}
?>

#輸出:

1 = F-A-001
9 = F-A-009
10 = F-A-010
99 = F-A-099
100 = F-A-100
999 = F-A-999
1000 = F-B-000
1009 = F-B-009
2099 = F-C-099
3999 = F-D-999
9999 = F-J-999
14999 = F-O-999
99999 = F-VD-999

################################ ###以上就是本文的全部內容,希望對大家的學習有所幫助。 ###############相關推薦:############PHP###實作透過strace定位故障原因的方法######## ##########PHP###使用file_get_contents發送http請求功能簡單##################PHP### MySQL高並發加鎖定交易處理問題解決方法############################

以上是php 根據自增id建立唯一編號類別的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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