10个数字、26个大写字母、26个小写字母,共 62 中状态
即可视为 62 进制数
pow(62, 4) = 14776336
即当连续递增的情况下,14776336 个之后才会出现重复
远远满足你的需要
即可视为 62 进制数
pow(62, 4) = 14776336
即当连续递增的情况下,14776336 个之后才会出现重复
远远满足你的需要
解决方案 »
- mysql left join 最后一条记录。
- discuz 论坛 如何加提示
- 网页中如何写带有用户名密码的WEB连接??
- 请教正则替换问题
- 我出现了一个内存不够的问题
- Warning: mysql_connect() [function.mysql-connect]: Access denied for user 'root'@'localhost' (using password: YES)
- -------有这样的控件可以使用吗?
- 无法显示数据库内容
- 哪为仁兄帮给忙,问一下怎么做检测是否在线?
- 为什么MYSQL会发生这个错误?
- 新手求问PHP函数调用问题
- 文件上传时$_FILES['XX']['tmp_name']临时文件的有效期求解???
那就是
pow(36, 4) = 1679616
也还是能够满足的
这样写产生9位的随机字符串 100w 应该没问题吧
/*
* 随机字符串
*/
function random_str($length)
{
$arr = array_merge(range('a', 'z'),range(0, 9));
$str = '';
$arr_len = count($arr);
for ($i = 0; $i < $length; $i++)
{
$rand = mt_rand(0, $arr_len-1);
$str.=$arr[$rand];
}
return $str;
}
mysql_connect();
mysql_select_db('test');
mysql_query('create temporary table a (ch varchar(9))');$len = 1000000;
for($i=0; $i<$len; $i++) {
$c = random_str(9);
mysql_query("insert into a values ('$c')") or die(mysql_error());
}
$rs = mysql_query('select ch, count(*) as cnt from a group by 1 having cnt>1') or die(mysql_error());
while($r = mysql_fetch_assoc($rs)) {
echo join(':', $r), PHP_EOL;
}
一次产生一百万个确实没有重复