网站建设资讯

NEWS

网站建设资讯

php随机取不重复数据库 mysql 随机取不重复数据

php随机生成数据库中不存在、不重复数字

说下思路:

专注于为中小企业提供网站建设、成都网站设计服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业满城免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千多家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

1. 将生成的数字保存到mysql数据库,然后每次生成的号码不能与数据库的数字重复,请问怎么弄?

先读取数据库已存在的数字,将结果以数组格式,与rand(1,1000)的数组相比较计算差集,去除这部分数字(array_diff),再shuffle,得到新的随机数。

我觉得,你完全可以建立一个序号表,比如,1-1000,每次用时先用随机函数取(1-数据记录数)个数值,再用这个数值取得相应的记录,当取出之后,删除这个记录,这样保证记录总数一直会减少且数字也不会重复。

2. 有没有什么办法生成的时候先生成一位数的,一位数生成满了以后再生出两位数的,两位数满了然后再三位数的,以此类推?

先获取一位数的记录,再从中随机抽取一个,如果数据库中没有找到一位数的,就递增一位数,直到找到为止。

3. 代码的执行效率希望能越高越好!

如果想要代码执行效率,最好尽量减少与数据库的交互。

PHP产生不重复随机数的5个方法总结

无论是Web应用,还是WAP或者移动应用,随机数都有其用武之地。在最近接触的几个小项目中,我也经常需要和随机数或者随机数组打交道,所以,对于PHP如何产生不重复随机数常用的几种方法小结一下(ps:方法1、4、5是我常用的,其余来自网络整理)

方法一:

复制代码

代码如下:

?php

$numbers

=

range

(1,50);

//shuffle

将数组顺序随即打乱

shuffle

($numbers);

//array_slice

取该数组中的某一段

$num=6;

$result

=

array_slice($numbers,0,$num);

print_r($result);

?

方法二:

复制代码

代码如下:

?php

$numbers

=

range

(1,20);

//播下随机数发生器种子,可有可无,测试后对结果没有影响

srand

((float)microtime()*1000000);

shuffle

($numbers);

//跳过list第一个值(保存的是索引)

while

(list(,

$number)

=

each

($numbers))

{

echo

"$number

";

}

?

方法三:

复制代码

代码如下:

?php

function

NoRand($begin=0,$end=20,$limit=5){

$rand_array=range($begin,$end);

shuffle($rand_array);//调用现成的数组随机排列函数

return

array_slice($rand_array,0,$limit);//截取前$limit个

}

print_r(NoRand());

?

上述可以在1-20间随机产生5个不重复的值

方法四:

复制代码

代码如下:

?php

$tmp=array();

while(count($tmp)5){

$tmp[]=mt_rand(1,20);

$tmp=array_unique($tmp);

}

print_r($tmp);

?

方法五:

复制代码

代码如下:

?php

$tmp

=

range(1,30);

print_r(array_rand($tmp,10));

?

这个可能是比叫简单的了(ps:如果在range中指定了步长,就必须注意array_rand的第二个参数是否超出$tmp的长度)。

PHP提供非常丰富的数组函数,产生随机数大多可以从数组这个角度出发,若你还有方法提供,欢迎给出,文章将持续更新。

php 如何实现,从数组中随机取出数据,还要保证下次不会再取到

每次随机取出一个数之后,应该删除这个数,才可以保证下次不取到它。例如你的100个数,第一次随机取一个,然后删除它,下次再剩余的99里面随机取一个,这样就不会重复了。

写代码没难度了吧,你写写看,如果希望我继续回答,建议你粘贴一下你写的内容,不完整或者错误没关系,至少你去思考了的,而且我看了代码知道你错在哪里,才可以针对性的讲解。

没空等你写代码了,我把我的贴出来,今天晚上要熬夜加班,没空回来看帖子了,不好意思,希望你认真学习。

?php

$arr=array();

for ($i=1;$i=100;$i++) array_push($arr,$i);

print_r($arr);

for ($i=1;$i=100;$i++){

$n=rand(0,count($arr)-1);//产生随机数,最小值是0,最大值是数组剩余元素可数-1

echo $arr[$n]," ";//显示取的随机数

array_slice($arr,$n,1);//删除刚才取到的数

}

?

mysql php thinkphp 随机选出不重复的数据

那要看你怎么筛选了, 如果是在统一方法里面循环筛选的话,那就把筛选出来的赋值到一个数组里面 然后再次筛选出来的时候就去匹配,如果有就不动,没有就再赋值到数组里。

如果是不同的方法,那就用session或者单独建个表去保存随机出的数据中的标识,再然后还是匹配


分享名称:php随机取不重复数据库 mysql 随机取不重复数据
本文地址:http://njwzjz.com/article/hijghe.html