怎样生成数据库中不重复的固定位数的数字?

php中文网
发布: 2016-06-06 20:44:02
原创
1789人浏览过

随机生成固定的位数(比如8位)的数字,

作为用户注册的uid存入数据库,

每个uid不重复,

但可以是12345678,12345677。

有种方法是随机生成8位数字,

然后查询数据库有无此数据,

有则重新生成在查询,

无则写入数据库,

奥硕企业网站管理系统终身免费版精简版1.0 build 090625
奥硕企业网站管理系统终身免费版精简版1.0 build 090625

奥硕企业网站管理系统具有一下特色功能1、双语双模(中英文采用单独模板设计,可制作中英文不同样式的网站)2、在线编辑JS动态菜单支持下拉效果,同时生成中文,英文,静态3个JS菜单3、在线制作并调用FLASH展示动画4、自动生成缩略图,可以自由设置宽高5、图片批量加水印,可以自由设置字体,大小,样式,水印位置(同时支持文字或图片类型水印)6、强大的标签式数据调用,可以调用(新闻,产品,下载,招聘)支持

奥硕企业网站管理系统终身免费版精简版1.0 build 090625 0
查看详情 奥硕企业网站管理系统终身免费版精简版1.0 build 090625

这样的方式比较费时。

有没有更好的方法,

比如结合别的随机值、时间戳之类的。

求解题思路或者方法,可用php实现

回复内容:

随机生成固定的位数(比如8位)的数字,

作为用户注册的uid存入数据库,

每个uid不重复,

但可以是12345678,12345677。

有种方法是随机生成8位数字,

然后查询数据库有无此数据,

有则重新生成在查询,

无则写入数据库,

这样的方式比较费时。

有没有更好的方法,

比如结合别的随机值、时间戳之类的。

求解题思路或者方法,可用php实现

通常数据库中存储的就是时间戳,也就是当前系统时间的毫秒数,然后除以1000,获取当前时间的秒数做为uid即可,因为如要存储的是毫秒的话,它占用数据库太长,用秒数即可保证唯一不重复。如果想让生成uid不只是数字还要有字母的话,可以将秒数转成16进制即可。

用户注册的uid,在某个范围自增就可以吧。
假设用户注册的qps没有那么高,可以利用update+私有复杂数据的方法在mongodb模拟一个锁,锁保护“上次注册的用户的uid”数据,每次拿锁,加一,注册,将锁保护的uid+1,释放锁即可。

唯一,非顺序:md5(uniqid());
顺序唯一:自增

使用时间戳,重复的几率几乎没有。

//生成0到1的随机小数
public  function randomFloat($min = 0, $max = 1) {
    return $min + mt_rand() / mt_getrandmax() * ($max - $min);
}
登录后复制

为什么怎么搞?不用主键自增?

uid最好还是用主键自增吧,然后php这边用mysql_insert_id()之类的函数取。这样查询操作也比较少。

创建一个自增列,起始值从10000000开始就行了。

很高兴为LZ解答这个问题。

首先,有什么东西是不停递增,并且不会重复的?

时间。

正如LZ猜想的那样,使用时间截转化成数字,可以产生始终递增并且不会重复的数字。

并且,这些数字还可以根据时间的推移,看大小就知道注册先后和注册时间。

这里仅仅是抛砖引玉。

$now=date("Y-m-d H:i:s");//按照 年月日,时分秒的格式,记录当前时间。
$unix_stamp=strtotime($now);
echo $unix_stamp;
/*strtotime函数预期一个包含美国英语日期格式的字符串,并尝试将其
解析为 Unix 时间戳(自 January 1 1970 00:00:00 GMT 起的秒数)
这里LZ大概会得到一个10位的数字。*/
登录后复制

LZ可以把$unix_stamp作为随机uid,如果认为秒数产生的数值不够随机的话

(比如1秒内有多人同时注册),可以在$unix_stamp后加上microtime()函数转换成数字

来使得这个数字更加随机,以避免uid重复的问题。

相关标签:
php
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号