加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 生成连续的五位字母数字ID

发布时间:2020-12-13 13:58:56 所属栏目:PHP教程 来源:网络整理
导读:总体概述: 下面的功能会吐出随机ID.我正在使用它来提供确认别名来识别记录.但是,我不得不检查碰撞(不大可能),因为我们只使用五位数的长度.使用下面列出的允许字符,它出现在3300万加上.最终我们会得到五百万左右的记录,所以碰撞成为一个问题. 问题: 检查欺
总体概述:

下面的功能会吐出随机ID.我正在使用它来提供确认别名来识别记录.但是,我不得不检查碰撞(不大可能),因为我们只使用五位数的长度.使用下面列出的允许字符,它出现在3300万加上.最终我们会得到五百万左右的记录,所以碰撞成为一个问题.

问题:

检查欺骗别名是低效和资源沉重的.五百万条记录是很多搜索.特别是当不同用户同时进行这种搜索时.

我的问题:

有没有办法“自动增加”这个功能允许的组合?意思我只需要搜索最后一条记录的别名并转到下一个组合?

确认限制:

我意识到代码将与下面的功能大不相同.我也意识到,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);

此时您可以尝试插入/更新,如果返回错误,则生成一个新别名,然后重试.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读