总体概述:
下面的函数吐出一个随机ID。我正在使用它来提供确认别名以识别记录。但是,我不得不检查碰撞(但是不太可能),因为我们只使用了五位数的长度。根据下面列出的允许的字符,总共有大约3,300万个组合。最终,我们将获得500万左右的记录,因此碰撞成为一个问题。
问题:
检查重复别名效率低下,而且占用大量资源。 500万条记录需要大量搜索。尤其是当不同用户同时进行此搜索时。
我的问题:
有没有一种方法可以“自动递增”此功能允许的组合?意思是我只需要搜索最后一条记录的别名并转到下一个组合?
公认的局限性:
我意识到代码将与下面的函数有很大的不同。我还意识到mysql具有用于数字ID的自动递增功能,但是该项目要求使用五位数字的别名,并允许使用字符“23456789ABCDEFGHJKLMNPQRSTUVWXYZ”。我在这个问题上束手无策。
我目前的职能:
public function random_id_gen($length)
{
$characters = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ';
$max = strlen($characters) - 1;
$string = '';
for ($i = 0; $i < $length; $i++) {
$string .= $characters[mt_rand(0, $max)];
}
return $string;
}
最佳答案
为什么不只在别名列上创建唯一索引?
CREATE UNIQUE INDEX uniq_alias ON MyTable(alias);
此时,您可以尝试插入/更新,如果返回错误,请生成新的别名,然后重试。
关于php - 生成连续的五位数字母数字ID,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6335633/