辦法就是一次性全查詢出來,然后用PHP程序來處理,優(yōu)點(diǎn)是減少數(shù)據(jù)庫連接查詢次數(shù),提高效率,缺點(diǎn)就是,有可能會(huì)多寫一部分php代碼??偟膩碚fphp的處理速度要比循環(huán)查詢要效率高。
我們提供的服務(wù)有:成都網(wǎng)站制作、做網(wǎng)站、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、河池ssl等。為1000+企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的河池網(wǎng)站制作公司
這當(dāng)然是不行的了,上面的告訴你的也是錯(cuò)誤的,因?yàn)樵蛟谟谀阊h(huán)的時(shí)候進(jìn)行了數(shù)據(jù)庫的查詢,所以每次都是新的數(shù)據(jù),指針當(dāng)然要從第一條開始了。
所以不是你的循環(huán)的錯(cuò)誤,而是你數(shù)據(jù)庫查詢代碼位置的錯(cuò)誤
要這樣寫
$num=mysql_query("select
*
from
china_city
where
parentid=0");
$n=
mysql_num_rows
($num);
for($i=1;$i=$n;$i++){
${"row".$i}=mysql_fetch_array($num);
echo
$i."
".${"row".$i}['city']."
";
}
一般都是用foreach或while寫的
foreach(mysql_fetch_array($num)
as
$key=$value){}
while($row
=mysql_fetch_array($num)){}
為什么不用while,那你可以去框架里面找一個(gè)寫好的方法,直接能返回所有查詢結(jié)果的數(shù)組,
function fetch_all($sql, $id = '') {
$arr = array();
$query = $this-query($sql);
while($data = $this-fetch_array($query)) {
$id ? $arr[$data[$id]] = $data : $arr[] = $data;
}
return $arr;
}
類似這種的 但是他里面還有其他方法,你不能直接調(diào)用,總之就是這個(gè)意思了。