不能對(duì)資源進(jìn)行foreach遍歷,$banner_db是資源、不是數(shù)組,foreach要求數(shù)組;
保亭黎族網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),保亭黎族網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為保亭黎族上千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的保亭黎族做網(wǎng)站的公司定做!
這類情況一般都是使用while ($row=mysqli_fetch($banner_db))來遍歷。
既然是遍歷,那就將數(shù)據(jù)庫指針先移到第一條記錄,逐次取出數(shù)據(jù)進(jìn)行運(yùn)算,下移指針,直到庫結(jié)束。
通常的代碼如下:
mysql_data_seek($result,0);//指針復(fù)位
while($row=mysql_fetch_array($result))?{?
//對(duì)每行記錄進(jìn)行運(yùn)算?處理,如?:echo?$row['name']."br?/";?
}
有2個(gè)辦法,第一種直接使用sql的多表聯(lián)查,效率高,但是得到的數(shù)據(jù)table1會(huì)被擴(kuò)展成table2一樣的條目數(shù) 要再次處理
select?*?from?table1?a,table2?b?where?a.orderid?=?b.orderid
第二種方法,先得到table11的數(shù)據(jù),在循環(huán)中匹配table2到一個(gè)新的列名中
$conn?=?mysqli_connect("127.0.0.1",?"root",?"123",?"test");
$sql?=?"select?*?from?table1";
$rs?=?mysqli_query($conn,?$sql);
$Arr?=?array();
while?($row?=?mysqli_fetch_assoc($rs))?{
$sql?=?"select?*?from?table2?where?orderid?="?.$row["orderid"];
$row["order_sku"]?=?mysqli_fetch_all(mysqli_query($conn,?$sql),?MYSQLI_ASSOC);
$Arr[]?=?$row;
}
print_r($Arr)
如果你是剛開始學(xué)php 建議直接拋棄mysql用mysqli 因?yàn)镻HP5.5已經(jīng)廢棄mysql方法了
第一、foreach()
foreach()是一個(gè)用來遍歷數(shù)組中數(shù)據(jù)的最簡單有效的方法。
?php
$urls= array('aaa','bbb','ccc','ddd');
foreach ($urls as $url){
echo "This Site url is $url! br /";
}
?
顯示結(jié)果:
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
第二、while() 和 list(),each()配合使用。
?php
$urls= array('aaa','bbb','ccc','ddd');
while(list($key,$val)= each($urls)) {
echo "This Site url is $val.br /";
}
?
顯示結(jié)果:
?
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
第三、for()運(yùn)用for遍歷數(shù)組
?php
$urls= array('aaa','bbb','ccc','ddd');
for ($i= 0;$i count($urls); $i++){
$str= $urls[$i];
echo "This Site url is $str.br /";
}
?
顯示結(jié)果:
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
這幾種遍歷數(shù)組的方法哪個(gè)更快捷些呢,下面做個(gè)簡單的測(cè)試就明白了
=========== 下面來測(cè)試三種遍歷數(shù)組的速度 ===========
一般情況下,遍歷一個(gè)數(shù)組有三種方法,for、while、foreach。其中最簡單方便的是foreach。下面先讓我們來測(cè)試一下共同遍歷一個(gè)有50000個(gè)下標(biāo)的一維數(shù)組所耗的時(shí)間。
?php
$arr= array();
for($i= 0; $i 50000; $i++){
$arr[]= $i*rand(1000,9999);
}
function GetRunTime()
{
list($usec,$sec)=explode(" ",microtime());
return ((float)$usec+(float)$sec);
}
######################################
$time_start= GetRunTime();
for($i= 0; $i count($arr); $i++){
$str= $arr[$i];
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of for:'.round($time_used, 7).'(s)br /br /';
unset($str, $time_start, $time_end, $time_used);
######################################
$time_start= GetRunTime();
while(list($key, $val)= each($arr)){
$str= $val;
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of while:'.round($time_used, 7).'(s)br /br /';
unset($str, $key, $val, $time_start, $time_end, $time_used);
######################################
$time_start= GetRunTime();
foreach($arr as$key= $val){
$str= $val;
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of foreach:'.round($time_used, 7).'(s)br /br /';
?
測(cè)試結(jié)果:
Used time of for:0.0228429(s)
Used time of while:0.0544658(s)
Used time of foreach:0.0085628(s)
結(jié)果表明,對(duì)于遍歷同樣一個(gè)數(shù)組,foreach速度最快,最慢的則是while。從原理上來看,foreach是對(duì)數(shù)組副本進(jìn)行操作(通過拷貝數(shù)組),而while則通過移動(dòng)數(shù)組內(nèi)部指標(biāo)進(jìn)行操作,一般邏輯下認(rèn)為,while應(yīng)該比foreach快(因?yàn)閒oreach在開始執(zhí)行的時(shí)候首先把數(shù)組復(fù)制進(jìn)去,而while直接移動(dòng)內(nèi)部指標(biāo)。),但結(jié)果剛剛相反。原因應(yīng)該是,foreach是PHP內(nèi)部實(shí)現(xiàn),而while是通用的循環(huán)結(jié)構(gòu)。所以,在通常應(yīng)用中foreach簡單,而且效率高。在PHP5下,foreach還可以遍歷類的屬性。
希望能夠喜歡。
/**
*???如果出現(xiàn)多級(jí)分類且在一張表中,?此時(shí)你需要增添字段確定分類間的關(guān)系
*???通常做法是在數(shù)據(jù)表中加一個(gè)字段如?'pid',?如果?id?==?pid?即判定為父子關(guān)系
*/
//?如這張表
//?如果需要找出中國下面的分類,只需要找出所有?pid?=?1?即可
SELECT?*?FROM?table?WHERE?pid?=?1;
其實(shí)就跟分頁獲取數(shù)據(jù)類似,網(wǎng)上這種例子就比較多了,分段獲取你可以把當(dāng)前獲取的最大的自增id存儲(chǔ)在文件、數(shù)據(jù)庫或者memcache中,下一段用大于這個(gè)做條件,然后遍歷完再更新這個(gè)數(shù)就行了。