php随机生成数据库中不存在、不重复数字
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php随机生成数据库中不存在、不重复数字相关的知识,希望对你有一定的参考价值。
现有1-200个数字,要求每往数据库中写入一条记录,就给这条记录的字段5(名字为:分配号)赋予一个1-200内的一个数字
每条记录的数字不能相同,也就是数据库中已有记录用到的数字新的记录就不能有了,请问怎么用PHP代码实现
数据库表大致如下
字段1 字段2 字段3 字段4 字段5
姓名 性别 年龄 证号 分配号
张三 男 15 123151 19
李四 女 17 123157 125
王五 男 13 155317 187
黑三 女 21 189745 6
分配号必须在1-200内,随机赋值,且不能与数据库现有记录已分配的重复
谢谢大家
1. 将生成的数字保存到mysql数据库,然后每次生成的号码不能与数据库的数字重复,请问怎么弄?
先读取数据库已存在的数字,将结果以数组格式,与rand(1,1000)的数组相比较计算差集,去除这部分数字(array_diff),再shuffle,得到新的随机数。
我觉得,你完全可以建立一个序号表,比如,1-1000,每次用时先用随机函数取(1-数据记录数)个数值,再用这个数值取得相应的记录,当取出之后,删除这个记录,这样保证记录总数一直会减少且数字也不会重复。
2. 有没有什么办法生成的时候先生成一位数的,一位数生成满了以后再生出两位数的,两位数满了然后再三位数的,以此类推?
先获取一位数的记录,再从中随机抽取一个,如果数据库中没有找到一位数的,就递增一位数,直到找到为止。
3. 代码的执行效率希望能越高越好!
如果想要代码执行效率,最好尽量减少与数据库的交互。追问
这是别人的答案,我已经看过了,别COPY
另外我要实现代码,谢谢
php中如何生成1-15之间的随机数?
php中如何自动生成1-15之间的随机数?
能实现吗?哪位能帮我写这段程序啊?非常感谢!
可以使用PHP math 函数 rand(1,15)直接返回即可。
定义和用法:rand() 函数返回随机整数。
语法:rand(min,max)。
参数:min,max 可选。规定随机数产生的范围。
说明:如果没有提供可选参数 min 和 max,rand() 返回 0 到 RAND_MAX 之间的伪随机整数。例如,想要 5 到 15(包括 5 和 15)之间的随机数,用 rand(5, 15)。
扩展资料:
提示和注释
注释:在某些平台下(例如 Windows)RAND_MAX 只有 32768。如果需要的范围大于 32768,那么指定 min 和 max 参数就可以生成大于 RAND_MAX 的数了,或者考虑用 mt_rand() 来替代它。
注释:自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函数给随机数发生器播种,现在已自动完成。
注释:在 3.0.7 之前的版本中,max 的含义是 range 。要在这些版本中得到和上例相同 5 到 15 的随机数,简短的例子是 rand (5, 11)。
参考资料来源:百度百科-PHP Math
参考技术A1、使用shuffle函数生成随机数。
<?php
$arr=range(1,10);
shuffle($arr);
foreach($arr as $values)
echo $values." ";
?>
2、使用array_unique函数生成随机数。
<?php
$arr=array();
while(count($arr)<10)
$arr[]=rand(1,10);
$arr=array_unique($arr);
echo implode(" ",$arr);
?>
3、使用array_flip函数生成随机数,可以去掉重复值。
<?php
$arr=array();
$count1=0;
$count = 0;
$return = array();
while ($count < 10)
$return[] = mt_rand(1, 10);
$return = array_flip(array_flip($return));
$count = count($return);
//www.jb51.net
foreach($return as $value)
echo $value." ";
echo "<br/>";
$arr=array_values($return);// 获得数组的值
foreach($arr as $key)
echo $key." ";
?>
扩展资料
Python中的shuffle()函数的使用:
解释说明:shuffle()函数是打乱序列里面的元素,并随机排列的。
使用说明:
import random
random.shuffle (alist )123
注意下:alist可以使是一个列表,也可以是个序列。shuffle()是不能直接访问的,需要导入random模块。
有一点需要注意: 下面这样的写法是错误的,不可以把随机排列的结果赋值给另外一个序列列表,只能在原序列列表的基础上操作。
alist2=random.shuffle(alist)
输出的结果为:None
可以使用php 中的 rand() 函数
rand(min,max)min,max 可选。规定随机数产生的范围。如果没有提供可选参数 min 和 max,rand() 返回 0 到 RAND_MAX 之间的伪随机整数。例如,想要 1 到 15(包括 1 和 15)之间的随机数,用 rand(1, 15)
<?php$s = rand(1, 15 );// $s 为返回1到15之间的随机数
echo $s;//输出 即可
?> 参考技术C <?php
$a = rand(1, 15 );//$a为1到15的随机数
echo $a;//输出
?>本回答被提问者采纳 参考技术D rand(1,15);
以上是关于php随机生成数据库中不存在、不重复数字的主要内容,如果未能解决你的问题,请参考以下文章