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


Posted in PHP onApril 06, 2017

在开发过程中,我们数据表一般都使用自增数字作为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);
    // 生成字母部分
    $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
?>

demo.php

<?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

源码下载地址:点击查看

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

PHP 相关文章推荐
用PHP进行MySQL删除记录操作代码
Jun 07 PHP
PHP 网页过期时间的控制代码
Jun 29 PHP
php利用iframe实现无刷新文件上传功能的代码
Sep 29 PHP
PHP中is_file不能替代file_exists的理由
Mar 04 PHP
php实现保存submit内容之后禁止刷新
Mar 19 PHP
PHP生成网站桌面快捷方式代码分享
Oct 11 PHP
php获取随机数组列表的方法
Nov 13 PHP
在WordPress中使用wp_count_posts函数来统计文章数量
Jan 05 PHP
总结PHP中数值计算的注意事项
Aug 14 PHP
Laravel学习教程之路由模块
Aug 18 PHP
PHP进阶学习之反射基本概念与用法分析
Jun 18 PHP
php设计模式之抽象工厂模式分析【星际争霸游戏案例】
Jan 23 PHP
php及codeigniter使用session-cookie的方法(详解)
Apr 06 #PHP
浅谈php(codeigniter)安全性注意事项
Apr 06 #PHP
详谈php ip2long 出现负数的原因及解决方法
Apr 05 #PHP
php生成0~1随机小数的方法(必看)
Apr 05 #PHP
php lcg_value与mt_rand生成0~1随机小数的效果对比分析
Apr 05 #PHP
php str_getcsv把字符串解析为数组的实现方法
Apr 05 #PHP
php 从指定数字中获取随机组合的简单方法(推荐)
Apr 05 #PHP
You might like
解析php file_exists无效的解决办法
2013/06/26 PHP
PHP实现时间比较和时间差计算的方法示例
2017/07/24 PHP
php屏蔽错误及提示的方法
2020/05/10 PHP
jQuery Ajax之load()方法
2009/10/12 Javascript
IE下Ajax缓存问题的快速解决方法(get方式)
2014/01/09 Javascript
情人节单身的我是如何在敲完代码之后收到12束玫瑰的(javascript)
2015/08/21 Javascript
APP中javascript+css3实现下拉刷新效果
2016/01/27 Javascript
jQuery简单实现列表隐藏和显示效果示例
2016/09/12 Javascript
根据Bootstrap Paginator改写的js分页插件
2016/12/25 Javascript
JavaScript Date 知识浅析
2017/01/29 Javascript
Vue中父组件向子组件通信的方法
2017/07/11 Javascript
AngularJS实现图片上传和预览功能的方法分析
2017/11/08 Javascript
Express进阶之log4js实用入门指南
2018/02/10 Javascript
jQuery实现表单动态添加数据并提交的方法
2018/07/19 jQuery
使用webpack搭建vue环境的教程详解
2019/12/31 Javascript
JS控制下拉列表左右选择实例代码
2020/05/08 Javascript
基于postman获取动态数据过程详解
2020/09/08 Javascript
Python的Flask框架中@app.route的用法教程
2015/03/31 Python
在Python中处理日期和时间的基本知识点整理汇总
2015/05/22 Python
一条命令解决mac版本python IDLE不能输入中文问题
2018/05/15 Python
python一行sql太长折成多行并且有多个参数的方法
2018/07/19 Python
python将list转为matrix的方法
2018/12/12 Python
kafka-python批量发送数据的实例
2018/12/27 Python
python turtle 绘制太极图的实例
2019/12/18 Python
Python趣味实例,实现一个简单的抽奖刮刮卡
2020/07/18 Python
西班牙最大的在线滑板和街头服饰商店:Fillow.net
2019/04/15 全球购物
jQuery treeview树形结构应用
2021/03/24 jQuery
优秀学生自我鉴定范例
2013/12/18 职场文书
2014年党课学习心得体会
2014/07/08 职场文书
2014年统计工作总结
2014/11/21 职场文书
护士个人年终总结
2015/02/13 职场文书
消夏晚会主持词
2015/06/30 职场文书
师德师风培训感言
2015/08/03 职场文书
关于教师节的广播稿
2015/08/19 职场文书
关于vue中如何监听数组变化
2021/04/28 Vue.js
React Fragment介绍与使用详解
2021/11/11 Javascript