程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php中通過數組進行高效隨機抽取指定條記錄的算法

php中通過數組進行高效隨機抽取指定條記錄的算法

編輯:PHP綜合

php使用數組array_rand()函數進行高效隨機抽取指定條數的記錄,可以隨機抽取數據庫中的記錄,適合進行隨機展示和抽獎程序。

該算法主要是利用php的array_rand()函數,下面看一下array_rand()函數的主要功能:

array_rand—從數組中隨機取出一個或多個單元

mixed array_rand(array $input[,int $num_req] )

array_rand()在你想從數組中取出一個或多個隨機的單元時相當有用。它接受input作為輸入數組和一個可選的參數num_req,指明了你想取出多少個單元 - 如果沒有指定,默認為 1。

如果你只取出一個,array_rand()返回一個隨機單元的鍵名,否則就返回一個包含隨機鍵名的數組。這樣你就可以隨機從數組中取出鍵名和值。

下面我們看一下小例子:

復制代碼 代碼如下:
<?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";
?>

該函數會隨機抽取$list數組中的記錄號,需要記錄內容只需要輸出即可。

下面看一段數據庫隨機抽取特定條記錄的例子:

復制代碼 代碼如下:
<?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);
?>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved