源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

php 根据自增id创建唯一编号类

  • 时间:2021-04-08 05:58 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:php 根据自增id创建唯一编号类
在开发过程中,我们数据表一般都使用自增数字作为id主键,而id是数字型,不容易理解。我们把id按一定格式转为编号后,很容易根据编号知道代表的是什么内容。 例如订单表id=[b]20160111197681234[/b],只看id我们并不知道这个id是订单表的id,而转为编号[b]O-20160111197681234[/b],则很容易看出是订单表的记录,然后可以根据id在订单表中搜寻。 [b]编号创建的规则[/b] [b]1.唯一 [/b] 使用自增id生成,保证唯一性 [b]2.尽可能短 [/b] 可使用数字求余对应字母的方式处理,创建较短的编号 [b]算法原理[/b] [b]1.加自定义前缀,用于标识[/b] [b]2.格式使用前缀+字母+数字组成,数字只保留N位,超过的使用数字求余的方式使用字母对应[/b] 例如: id=1 前缀=F 数字保留3位 则创建的编号为:[b]F-A-001 [/b] 代码如下: [b]IDCode.class.PHP[/b]
<?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);
    // 生成字母部分
    $division = (int)($id/$base);
    $word = '';
    while($division){
      $tmp = fmod($division, 26); // 只使用26个大写字母
      $tmp = chr($tmp + 65);   // 转为字母
      $word .= $tmp;
      $division = floor($division/26);
    }
    if($word==''){
      $word = chr(65);
    }
    // 生成数字部分
    $mod = $id % $base;
    $digital = str_pad($mod, $num_length, 0, STR_PAD_LEFT);
    $code = sprintf('%s-%s-%s', $prefix, $word, $digital);
    return $code;
  }
} // class end
?>
[b]demo.php[/b]
<?php
require 'IDCode.class.php';
$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.' = '.IDCode::create($test_id, 3, 'F').'<br>';
}
?>
输出:
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
[b]源码下载地址:[url=http://xiazai.jb51.net/201704/yuanma/IDCode-master_jb51.rar]点击查看[/url][/b] 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程素材网!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部