用array_rand()函數(shù)吧,它可以從一個(gè)數(shù)組中隨機(jī)取一個(gè)或者多個(gè)下標(biāo)出來(lái),有了下標(biāo),就可以從原數(shù)組拿到對(duì)應(yīng)的元素了。它的用法也很簡(jiǎn)單:array_rand($arr[,
為平?jīng)龅鹊貐^(qū)用戶(hù)提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及平?jīng)鼍W(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、平?jīng)鼍W(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專(zhuān)業(yè)、用心的態(tài)度為用戶(hù)提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶(hù)的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
$num])$arr
==
用來(lái)取元素的數(shù)組$num
==
隨機(jī)取下標(biāo)的個(gè)數(shù)其中第二個(gè)參數(shù)
$num
是可選的,默認(rèn)為1
。注意:它的返回值在第二個(gè)參數(shù)大于
1
的時(shí)候是一個(gè)數(shù)組;當(dāng)?shù)诙€(gè)參數(shù)不設(shè)或者傳值
1
的時(shí)候是一個(gè)下標(biāo)。簡(jiǎn)單的示例代碼如下:1、第二個(gè)參數(shù)不傳值的情況;$arr
=
Array('a',
'b');$rndKey
=
array_rand($arr);echo
$arr[$rndKey];//輸出
a
或者
b2、第二個(gè)參數(shù)傳值大于
1
的情況;$arr
=
Array('a',
'b',
'c',
'd');$rndKey
=
array_rand($arr,
2);print_r($rndKey]);//輸出一個(gè)隨機(jī)key的數(shù)組
//連接數(shù)據(jù)庫(kù)
if(!$con = mysql_connect("localhost","root","root")){die(mysql_error());}
mysql_select_db("ali_xt");
mysql_query('set names utf8');
//找出ali_admin表的字段
$res = mysql_query('show columns from ali_admin');
//將數(shù)據(jù)給弄出來(lái)
$data = array();
while ($row = mysql_fetch_assoc($res, MYSQL_NUM)) {
$data[] = $row;
}
//隨機(jī)個(gè)數(shù),默認(rèn)5
$rand_times = 5;
$rand_times = count($data)$rand_times?count($data):$rand_times;
$result = array();
for( $i=0;$i$rand_times;$i++ ){
$result[] = $data[rand(0,count($data)-1)][0];
}
echo "pre";
print_r($result); //輸出5個(gè)隨機(jī)字段
mysql_close($con);
//純手寫(xiě)的,不明白可以問(wèn)我,記得給分
/**
*?MySQL?隨機(jī)取記錄
*?
*?@param?$t?表
*?@param?$c?ID列,默認(rèn)為id
*?@param?$n?取多少個(gè)
*?@param?$w?條件語(yǔ)句
*?@param?$f?bool?是否強(qiáng)制以多維數(shù)組形式返回,默認(rèn)false
*?@return?array?取1個(gè)直接返回結(jié)果數(shù)組(除非$f為true),取1個(gè)返回多維數(shù)組,用foreach取出
*/
function?rand_row($t?,?$c?=?'id'?,?$n?=?'1',?$w?=?''?,?$f?=?false)?{
$m=new?mysqli(mysqli信息,自行查找php文檔);
if?(!empty($w))?{
$w?=?'?AND?'.$w;
}
$sql?=?"SELECT?*?FROM?`{$t}`?WHERE?{$c}?=?(SELECT?floor(RAND()?*?(SELECT?MAX({$c})?FROM?`{$t}`)))?{$w}?ORDER?BY?{$c}?LIMIT?{$n};";
$xq??=?$m-query($sql);
$r???=?array();
while?($x?=?$m-fetch_array($xq))?{
$r[]?=?$x;
}
if?($f?==?false??count($r)?==?1)?{
return?$r[0];
}?else?{
return?$r;
}
}
array_rand()
在你想從數(shù)組中取出一個(gè)或多個(gè)隨機(jī)的單元時(shí)相當(dāng)有用。它接受
input
作為輸入數(shù)組和一個(gè)可選的參數(shù)
num_req,指明了你想取出多少個(gè)單元
-
如果沒(méi)有指定,默認(rèn)為
1。
如果你只取出一個(gè),array_rand()
返回一個(gè)隨機(jī)單元的鍵名,否則就返回一個(gè)包含隨機(jī)鍵名的數(shù)組。這樣你就可以隨機(jī)從數(shù)組中取出鍵名和值。
主要是用array_rand()方法
$a
=
range(1,100);
function
get_one($a){
if(count($a)=1){
$key=array_rand($a,1);
$value=$a[$key];
unset($a[$key]);
return
$value;
}else{
return
"都取光了";
}
}
//每次取值可以直接
echo
"取到的值:".get_one($a);
echo
"br還剩:".count($a);
網(wǎng)站欄目:php從數(shù)據(jù)中隨機(jī)抽取,php隨機(jī)取數(shù)據(jù)庫(kù)內(nèi)容
分享鏈接:http://sd-ha.com/article44/dseeoee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、品牌網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、微信公眾號(hào)、云服務(wù)器、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)