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); 此时您可以尝试插入/更新,如果返回错误,则生成一个新别名,然后重试. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |