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内,随机赋值,且不能与数据库现有记录已分配的重复

谢谢大家

参考技术A 说下思路:

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

参考技术A

1、使用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

参考技术B

可以使用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随机生成数据库中不存在、不重复数字的主要内容,如果未能解决你的问题,请参考以下文章

php生成三个数字并且任意两个不重复

如果 PHP 中不存在,则复制文件并创建目录 [重复]

php生成随机数字,范围1-100,每次生成一个数字,可以重复

求PHP语言随机自动生成不重复的数字

生成多个不重复的随机数字php

生成多个不重复的随机数字php