在php中要隨機取mysql記錄我們可以直接使用mysql_query來執行mysql中的select rand函數獲取的數據并讀出來,這里就來給大家簡單介紹一下.
目前成都創新互聯公司已為上千家的企業提供了網站建設、域名、網站空間、成都網站托管、企業網站設計、余杭網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協力一起成長,共同發展。
方法一,代碼如下:
復制代碼代碼如下:
select * from tablename order by rand() limit 1
把 limit 后面的數值改為你想隨機抽取的條數,這里只取一條.
方法二,代碼如下:
復制代碼代碼如下:
$query= "SELECT count(*) as count FROM recommends";
....
$max_num = $row['count']; // 取記錄總數
srand((double)microtime()*1000000); // 隨機數種子
$se_pos = rand(0, $max_num); // 隨機數范圍
$length = 6; // 記錄條數
if (($max_num - $se_pos) = $length) {
$se_pos = $max_num - $se_pos; // 記錄數不足6條的情況
}
$query = "SELECT * FROM recommendsn limit ".$se_pos.",".$length;
例3,假設有一個名為xyj的數據庫,庫中有表obj,表中有一字段為name,現在要實現從表里隨機選取一條記錄,具體程序如下:
復制代碼代碼如下:
?php
$db = mysql_connect("localhost", "root");
mysql_select_db("xyj",$db);
$result=mysql_query("SELECT * FROM obj",$db);
$max_num=mysql_num_rows($result);//取得數據庫的記錄數
srand((double)microtime()*10000000); //生成隨機數種子。
$se_pos=rand(0, $max_num-1); //從0到最大記錄數取隨機數
$length=30; //設定共取多少條記錄
//下面是取出指定數目的記錄。
$result_lim=mysql_query("select * from obj limit $se_pos,$length",$db);
$myrow_lim=mysql_fetch_array($result_lim);
printf("%sn", $se_pos);//顯示隨機得到的記錄號
printf("%sn", $myrow_lim["name"]);//顯示隨機得到的記錄的name字段
?
/**
*?MySQL?隨機取記錄
*?
*?@param?$t?表
*?@param?$c?ID列,默認為id
*?@param?$n?取多少個
*?@param?$w?條件語句
*?@param?$f?bool?是否強制以多維數組形式返回,默認false
*?@return?array?取1個直接返回結果數組(除非$f為true),取1個返回多維數組,用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;
}
}
//連接數據庫
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');
//將數據給弄出來
$data = array();
while ($row = mysql_fetch_assoc($res, MYSQL_NUM)) {
$data[] = $row;
}
//隨機個數,默認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個隨機字段
mysql_close($con);
//純手寫的,不明白可以問我,記得給分
你可以直接在sql 里寫隨機 select name from users where state='1' and weiname!='' and imageurl!='' and sex!='' order by rand() limit...
說下思路:
1. 將生成的數字保存到mysql數據庫,然后每次生成的號碼不能與數據庫的數字重復,請問怎么弄?
先讀取數據庫已存在的數字,將結果以數組格式,與rand(1,1000)的數組相比較計算差集,去除這部分數字(array_diff),再shuffle,得到新的隨機數。
我覺得,你完全可以建立一個序號表,比如,1-1000,每次用時先用隨機函數取(1-數據記錄數)個數值,再用這個數值取得相應的記錄,當取出之后,刪除這個記錄,這樣保證記錄總數一直會減少且數字也不會重復。
2. 有沒有什么辦法生成的時候先生成一位數的,一位數生成滿了以后再生出兩位數的,兩位數滿了然后再三位數的,以此類推?
先獲取一位數的記錄,再從中隨機抽取一個,如果數據庫中沒有找到一位數的,就遞增一位數,直到找到為止。
3. 代碼的執行效率希望能越高越好!
如果想要代碼執行效率,最好盡量減少與數據庫的交互。
$mysql_server_name="localhost";?//數據庫服務器名稱
$mysql_username="root";?//?連接數據庫用戶名
$mysql_password="??????";?//?連接數據庫密碼
$mysql_database="??????";?//?數據庫的名字
//?連接到數據庫
$conn=mysql_connect($mysql_server_name,?$mysql_username,$mysql_password);???????????????????
//?從表中提取信息的sql語句
$strsql="SELECT?*?FROM?表名?WHERE?type='交友'";
//?執行sql查詢
$result=mysql_db_query($mysql_database,?$strsql,?$conn);
//?獲取查詢結果
var_dump(array_rand($result));
分享標題:php隨機一條數據庫 php 隨機
轉載注明:http://vcdvsql.cn/article20/doodeco.html
成都網站建設公司_創新互聯,為您提供ChatGPT、小程序開發、Google、手機網站建設、網站營銷、企業建站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯