总体概述:

下面的函数吐出一个随机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/

10-10 13:35
查看更多