獲取數(shù)據(jù)庫資料時(shí)進(jìn)行篩選。如果你想要 a字段不重復(fù)那么就如
成都創(chuàng)新互聯(lián)是一家專注于網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),衡東網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:衡東等地區(qū)。衡東做網(wǎng)站價(jià)格咨詢:028-86922220
select distinct a from table where ……
無論是Web應(yīng)用,還是WAP或者移動(dòng)應(yīng)用,隨機(jī)數(shù)都有其用武之地。在最近接觸的幾個(gè)小項(xiàng)目中,我也經(jīng)常需要和隨機(jī)數(shù)或者隨機(jī)數(shù)組打交道,所以,對(duì)于PHP如何產(chǎn)生不重復(fù)隨機(jī)數(shù)常用的幾種方法小結(jié)一下(ps:方法1、4、5是我常用的,其余來自網(wǎng)絡(luò)整理)
方法一:
復(fù)制代碼
代碼如下:
?php
$numbers
=
range
(1,50);
//shuffle
將數(shù)組順序隨即打亂
shuffle
($numbers);
//array_slice
取該數(shù)組中的某一段
$num=6;
$result
=
array_slice($numbers,0,$num);
print_r($result);
?
方法二:
復(fù)制代碼
代碼如下:
?php
$numbers
=
range
(1,20);
//播下隨機(jī)數(shù)發(fā)生器種子,可有可無,測(cè)試后對(duì)結(jié)果沒有影響
srand
((float)microtime()*1000000);
shuffle
($numbers);
//跳過list第一個(gè)值(保存的是索引)
while
(list(,
$number)
=
each
($numbers))
{
echo
"$number
";
}
?
方法三:
復(fù)制代碼
代碼如下:
?php
function
NoRand($begin=0,$end=20,$limit=5){
$rand_array=range($begin,$end);
shuffle($rand_array);//調(diào)用現(xiàn)成的數(shù)組隨機(jī)排列函數(shù)
return
array_slice($rand_array,0,$limit);//截取前$limit個(gè)
}
print_r(NoRand());
?
上述可以在1-20間隨機(jī)產(chǎn)生5個(gè)不重復(fù)的值
方法四:
復(fù)制代碼
代碼如下:
?php
$tmp=array();
while(count($tmp)5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
?
方法五:
復(fù)制代碼
代碼如下:
?php
$tmp
=
range(1,30);
print_r(array_rand($tmp,10));
?
這個(gè)可能是比叫簡單的了(ps:如果在range中指定了步長,就必須注意array_rand的第二個(gè)參數(shù)是否超出$tmp的長度)。
PHP提供非常豐富的數(shù)組函數(shù),產(chǎn)生隨機(jī)數(shù)大多可以從數(shù)組這個(gè)角度出發(fā),若你還有方法提供,歡迎給出,文章將持續(xù)更新。
你可以這樣,你有一張ip_code表格,你加一個(gè)字段為state,你每次取的時(shí)候把state標(biāo)為1,而沒取得為0,那么每次拿都是去拿為0的。