在php中要隨機(jī)取mysql記錄我們可以直接使用mysql_query來(lái)執(zhí)行mysql中的select rand函數(shù)獲取的數(shù)據(jù)并讀出來(lái),這里就來(lái)給大家簡(jiǎn)單介紹一下.
目前成都創(chuàng)新互聯(lián)公司已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、成都網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、余杭網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
方法一,代碼如下:
復(fù)制代碼代碼如下:
select * from tablename order by rand() limit 1
把 limit 后面的數(shù)值改為你想隨機(jī)抽取的條數(shù),這里只取一條.
方法二,代碼如下:
復(fù)制代碼代碼如下:
$query= "SELECT count(*) as count FROM recommends";
....
$max_num = $row['count']; // 取記錄總數(shù)
srand((double)microtime()*1000000); // 隨機(jī)數(shù)種子
$se_pos = rand(0, $max_num); // 隨機(jī)數(shù)范圍
$length = 6; // 記錄條數(shù)
if (($max_num - $se_pos) = $length) {
$se_pos = $max_num - $se_pos; // 記錄數(shù)不足6條的情況
}
$query = "SELECT * FROM recommendsn limit ".$se_pos.",".$length;
例3,假設(shè)有一個(gè)名為xyj的數(shù)據(jù)庫(kù),庫(kù)中有表obj,表中有一字段為name,現(xiàn)在要實(shí)現(xiàn)從表里隨機(jī)選取一條記錄,具體程序如下:
復(fù)制代碼代碼如下:
?php
$db = mysql_connect("localhost", "root");
mysql_select_db("xyj",$db);
$result=mysql_query("SELECT * FROM obj",$db);
$max_num=mysql_num_rows($result);//取得數(shù)據(jù)庫(kù)的記錄數(shù)
srand((double)microtime()*10000000); //生成隨機(jī)數(shù)種子。
$se_pos=rand(0, $max_num-1); //從0到最大記錄數(shù)取隨機(jī)數(shù)
$length=30; //設(shè)定共取多少條記錄
//下面是取出指定數(shù)目的記錄。
$result_lim=mysql_query("select * from obj limit $se_pos,$length",$db);
$myrow_lim=mysql_fetch_array($result_lim);
printf("%sn", $se_pos);//顯示隨機(jī)得到的記錄號(hào)
printf("%sn", $myrow_lim["name"]);//顯示隨機(jī)得到的記錄的name字段
?
/**
*?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;
}
}
//連接數(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);
//純手寫的,不明白可以問(wèn)我,記得給分
你可以直接在sql 里寫隨機(jī) select name from users where state='1' and weiname!='' and imageurl!='' and sex!='' order by rand() limit...
說(shuō)下思路:
1. 將生成的數(shù)字保存到mysql數(shù)據(jù)庫(kù),然后每次生成的號(hào)碼不能與數(shù)據(jù)庫(kù)的數(shù)字重復(fù),請(qǐng)問(wèn)怎么弄?
先讀取數(shù)據(jù)庫(kù)已存在的數(shù)字,將結(jié)果以數(shù)組格式,與rand(1,1000)的數(shù)組相比較計(jì)算差集,去除這部分?jǐn)?shù)字(array_diff),再shuffle,得到新的隨機(jī)數(shù)。
我覺(jué)得,你完全可以建立一個(gè)序號(hào)表,比如,1-1000,每次用時(shí)先用隨機(jī)函數(shù)?。?-數(shù)據(jù)記錄數(shù))個(gè)數(shù)值,再用這個(gè)數(shù)值取得相應(yīng)的記錄,當(dāng)取出之后,刪除這個(gè)記錄,這樣保證記錄總數(shù)一直會(huì)減少且數(shù)字也不會(huì)重復(fù)。
2. 有沒(méi)有什么辦法生成的時(shí)候先生成一位數(shù)的,一位數(shù)生成滿了以后再生出兩位數(shù)的,兩位數(shù)滿了然后再三位數(shù)的,以此類推?
先獲取一位數(shù)的記錄,再?gòu)闹须S機(jī)抽取一個(gè),如果數(shù)據(jù)庫(kù)中沒(méi)有找到一位數(shù)的,就遞增一位數(shù),直到找到為止。
3. 代碼的執(zhí)行效率希望能越高越好!
如果想要代碼執(zhí)行效率,最好盡量減少與數(shù)據(jù)庫(kù)的交互。
$mysql_server_name="localhost";?//數(shù)據(jù)庫(kù)服務(wù)器名稱
$mysql_username="root";?//?連接數(shù)據(jù)庫(kù)用戶名
$mysql_password="??????";?//?連接數(shù)據(jù)庫(kù)密碼
$mysql_database="??????";?//?數(shù)據(jù)庫(kù)的名字
//?連接到數(shù)據(jù)庫(kù)
$conn=mysql_connect($mysql_server_name,?$mysql_username,$mysql_password);???????????????????
//?從表中提取信息的sql語(yǔ)句
$strsql="SELECT?*?FROM?表名?WHERE?type='交友'";
//?執(zhí)行sql查詢
$result=mysql_db_query($mysql_database,?$strsql,?$conn);
//?獲取查詢結(jié)果
var_dump(array_rand($result));