php中通過(guò)數(shù)組進(jìn)行高效隨機(jī)抽取指定條記錄的算法
php使用數(shù)組array_rand()函數(shù)進(jìn)行高效隨機(jī)抽取指定條數(shù)的記錄,可以隨機(jī)抽取數(shù)據(jù)庫(kù)中的記錄,適合進(jìn)行隨機(jī)展示和抽獎(jiǎng)程序。
該算法主要是利用php的array_rand()函數(shù),下面看一下array_rand()函數(shù)的主要功能:
array_rand—從數(shù)組中隨機(jī)取出一個(gè)或多個(gè)單元
mixed array_rand(array $input[,int $num_req] )
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ù)組中取出鍵名和值。
下面我們看一下小例子:
<?php
srand((float) microtime() * 10000000);
$input = array("Neo", "Morpheus", "Trinity", "Cypher", "Tank");
$rand_keys = array_rand($input, 2);
print $input[$rand_keys[0]] . "\n";
print $input[$rand_keys[1]] . "\n";
?>
該函數(shù)會(huì)隨機(jī)抽取$list數(shù)組中的記錄號(hào),需要記錄內(nèi)容只需要輸出即可。
下面看一段數(shù)據(jù)庫(kù)隨機(jī)抽取特定條記錄的例子:
<?php
$list = $DB->where("status=1 and flag=1")->order('sort')->select();
unset($Case);
$count = count($list);
$rand_list=range(0, $count-1);
$rand_list = array_rand($rand_list, 10);
$tuijian_array = array();
foreach ($rand_list as $key) {
$tuijian_array[] = $list[$key];
}
unset($case_list);
print_r($tuijian_array);
?>
相關(guān)文章
php讀取二進(jìn)制流(C語(yǔ)言結(jié)構(gòu)體struct數(shù)據(jù)文件)的深入解析
本篇文章是對(duì)php讀取二進(jìn)制流(C語(yǔ)言結(jié)構(gòu)體struct數(shù)據(jù)文件)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
PHP使用flock實(shí)現(xiàn)文件加鎖的方法
這篇文章主要介紹了PHP使用flock實(shí)現(xiàn)文件加鎖的方法,實(shí)例分析了flock文件鎖的使用技巧,需要的朋友可以參考下2015-07-07
批量獲取memcache值并按key的順序返回的實(shí)現(xiàn)代碼
一臺(tái)memcache時(shí)返回是正確的,在有多臺(tái)memcache時(shí)就無(wú)法一一對(duì)應(yīng)的按順序返回。2011-06-06
php實(shí)現(xiàn)將任意進(jìn)制數(shù)轉(zhuǎn)換成10進(jìn)制的方法
phpstudy無(wú)法啟動(dòng)MySQL服務(wù)的三種問(wèn)題解決
php 強(qiáng)制下載文件實(shí)現(xiàn)代碼
PHP多線程抓取網(wǎng)頁(yè)實(shí)現(xiàn)代碼

