php隨機(jī)一條數(shù)據(jù)庫 php 隨機(jī)

在PHP中如何像一個(gè)數(shù)據(jù)表隨機(jī)寫入100條記錄??數(shù)據(jù)表是student_info

在php中要隨機(jī)取mysql記錄我們可以直接使用mysql_query來執(zhí)行mysql中的select rand函數(shù)獲取的數(shù)據(jù)并讀出來,這里就來給大家簡單介紹一下.

目前成都創(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é)力一起成長,共同發(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ù)庫,庫中有表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ù)庫的記錄數(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字段

?

如何在數(shù)據(jù)庫中隨機(jī)取出1條記錄?PHP

/**

*?MySQL?隨機(jī)取記錄

*?

*?@param?$t?表

*?@param?$c?ID列,默認(rèn)為id

*?@param?$n?取多少個(gè)

*?@param?$w?條件語句

*?@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;

}

}

php語句,怎么從數(shù)據(jù)庫中隨機(jī)獲取數(shù)據(jù)字段。

//連接數(shù)據(jù)庫

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ù)給弄出來

$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);

//純手寫的,不明白可以問我,記得給分

php select 查詢數(shù)據(jù)庫的時(shí)候,如何 echo 查詢到的隨機(jī)一個(gè)值

你可以直接在sql 里寫隨機(jī) select name from users where state='1' and weiname!='' and imageurl!='' and sex!='' order by rand() limit...

php隨機(jī)生成數(shù)據(jù)庫中不存在、不重復(fù)數(shù)字

說下思路:

1. 將生成的數(shù)字保存到mysql數(shù)據(jù)庫,然后每次生成的號(hào)碼不能與數(shù)據(jù)庫的數(shù)字重復(fù),請(qǐng)問怎么弄?

先讀取數(shù)據(jù)庫已存在的數(shù)字,將結(jié)果以數(shù)組格式,與rand(1,1000)的數(shù)組相比較計(jì)算差集,去除這部分?jǐn)?shù)字(array_diff),再shuffle,得到新的隨機(jī)數(shù)。

我覺得,你完全可以建立一個(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. 有沒有什么辦法生成的時(shí)候先生成一位數(shù)的,一位數(shù)生成滿了以后再生出兩位數(shù)的,兩位數(shù)滿了然后再三位數(shù)的,以此類推?

先獲取一位數(shù)的記錄,再從中隨機(jī)抽取一個(gè),如果數(shù)據(jù)庫中沒有找到一位數(shù)的,就遞增一位數(shù),直到找到為止。

3. 代碼的執(zhí)行效率希望能越高越好!

如果想要代碼執(zhí)行效率,最好盡量減少與數(shù)據(jù)庫的交互。

php,選擇“數(shù)據(jù)庫表里”符合某個(gè)條件的多個(gè)數(shù)據(jù),然后怎么再隨機(jī)選取一個(gè)?

$mysql_server_name="localhost";?//數(shù)據(jù)庫服務(wù)器名稱

$mysql_username="root";?//?連接數(shù)據(jù)庫用戶名

$mysql_password="??????";?//?連接數(shù)據(jù)庫密碼

$mysql_database="??????";?//?數(shù)據(jù)庫的名字

//?連接到數(shù)據(jù)庫

$conn=mysql_connect($mysql_server_name,?$mysql_username,$mysql_password);???????????????????

//?從表中提取信息的sql語句

$strsql="SELECT?*?FROM?表名?WHERE?type='交友'";

//?執(zhí)行sql查詢

$result=mysql_db_query($mysql_database,?$strsql,?$conn);

//?獲取查詢結(jié)果

var_dump(array_rand($result));

分享標(biāo)題:php隨機(jī)一條數(shù)據(jù)庫 php 隨機(jī)
轉(zhuǎn)載注明:http://www.muchs.cn/article20/doodeco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT小程序開發(fā)、Google手機(jī)網(wǎng)站建設(shè)網(wǎng)站營銷、企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)