在开发过程中,我们数据表一般都使用自增数字作为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;">
demo.PHP
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').'
'; } ?>
'; } ?>
输出: