自定义唯一ID在PHP,MySql中生成

时间:2015-02-21 08:55:07

标签: php mysql unique-id

我想为我存储在mysql数据库中的每个项目创建自动但自定义的id很少帮助。就像我输入1项pepe牛仔裤颜色“黑色”和腰围30.这个产品的唯一ID将是PEPE + BLACK + 30 + A001,A001是一个独特的数字,它会像A001,A002,A003一样增加...... .A999到达A999后,这个数字将变为B001,然后是B002,B003 ......等等。 Plz向我展示了这样做的逻辑。

1项ID的示例将是:PEPEBLACK30A009

#thanks:)

2 个答案:

答案 0 :(得分:1)

你可以有类似的东西:

$lastId = 'A999';
$letter = $lastId[0];
echo $letter;
$number = $lastId[1].$lastId[2].$lastId[3];
echo $number;

if ($number < 999) {
    $newId = $letter.sprintf("%03d", $number+1);
} else {
    $ascii = ord($letter);
    $newLetter = chr($ascii+1);
    $newId = $newLetter.'001';
}

echo $newId;

请记住,在字符Z之后,这将打印其他符号,因此可能需要一些tweeking。

答案 1 :(得分:0)

创建一个自动递增的主ID列(0 - 28971),然后您可以获取此ID号并将其转换为您的格式。

转换了几个ID的示例:

<?php

for ($i = 0; $i < 5000; $i += 99) {
    $num     = $i;
    $letters = range('A', 'Z');
    $letter  = (int) $num / 999;
    $num     = $num % 999 + 1;
    $num     = str_pad($num, 3, 0, STR_PAD_LEFT);
    echo $i . ' => ' . $letters[$letter] . $num . "\n";
}

输出:

0 => A001
99 => A100
198 => A199
297 => A298
396 => A397
495 => A496
594 => A595
693 => A694
792 => A793
891 => A892
990 => A991
1089 => B091
1188 => B190
1287 => B289
1386 => B388
1485 => B487
1584 => B586
1683 => B685
1782 => B784
1881 => B883
1980 => B982
2079 => C082
2178 => C181
2277 => C280
2376 => C379
2475 => C478
2574 => C577
2673 => C676
2772 => C775
2871 => C874
2970 => C973

Rest

问题当然是主键的限制为28971,因为只有26个字母(26 * 999),但当然你可以有4个/更多的数字,或者将来添加更多的字母。