數(shù)據(jù)庫提到的數(shù)據(jù)一般是資源類型的,要逐一讀出,添加到數(shù)組
衡東網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),衡東網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為衡東1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務(wù)好的衡東做網(wǎng)站的公司定做!
while($row = mysql_fetch_assoc($res)){
$data[] = $row;
}
一、什么是數(shù)組
數(shù)組就是一組數(shù)據(jù)的集合,把一系列數(shù)據(jù)組織起來,形成一個可操作的整體。數(shù)組的每個實體都包含兩項:鍵和值。
二、聲明數(shù)據(jù)
在PHP中聲明數(shù)組的方式主要有兩種:一是應(yīng)用array()函數(shù)聲明數(shù)組,一是直接為數(shù)組元素賦值。
1array()函數(shù)聲明的數(shù)組的方式array([mixed...]) 參數(shù)mixed的語法為key=value
如,?php
$array=array("1"="編","2"="程","3"="詞","4"="典");
print_r($array);
echo "br";
echo $array[1]; //注意:下標(biāo)默認(rèn)是從0開始
echo $array[2];
echo $array[3];
echo $array[4];
?
2直接為數(shù)組元素賦值。如果在創(chuàng)建數(shù)組時不知所創(chuàng)建數(shù)組的大小,或在實際編寫程序時數(shù)組的大小可能發(fā)生變化,采用這種數(shù)組創(chuàng)建的方法較好。
如,?php
$array[1]="I";
$array[2]="love";
$array[3]="PHP";
print_r($array); //輸出所創(chuàng)建數(shù)組的結(jié)構(gòu)
?
三、數(shù)組的類型
PHP支持兩種數(shù)組:索引數(shù)組(indexed array)和聯(lián)合數(shù)組(associative array),前者使用數(shù)字作為鍵,后者使用字符串作為鍵。
四、輸出數(shù)組
在PHP中對數(shù)組元素輸出,可以通過echo和print語句來實現(xiàn),但這只能對數(shù)組中某一元素進(jìn)行輸出;要將數(shù)組結(jié)構(gòu)輸出則要使用print_r()函數(shù),其語法:print_r(mixed expression_r),參數(shù)expression_r為普通的整形、字符型或?qū)嵭妥兞縿t輸出該變量本身,如果該參數(shù)為數(shù)組,則按一定鍵值和元素的順序顯示出該數(shù)組中的所有元素。
五、數(shù)組的構(gòu)造
一維數(shù)組:
當(dāng)一個數(shù)組的元素是變量時,則稱其為一維數(shù)組。
聲明一位數(shù)組: 類型說明符 數(shù)組名[常量表達(dá)式];
二維數(shù)組:
當(dāng)一個數(shù)組的元素是一個一位數(shù)組時,則稱之為二維數(shù)組。
如,?php
$str = array (
"網(wǎng)絡(luò)編程語言"=array ("PHP","JSP","ASP"),
"體育項目"=array ("m"="足球","n"="籃球"));
print_r ( $str) ;
?
六、遍歷數(shù)組
遍歷數(shù)組中的所有元素是常用的一種操作,在遍歷的過程中可以完成查詢或其他功能。在PHP中遍歷數(shù)組的方法有多種,下面介紹最常用的兩種方法。
1使用foreach結(jié)構(gòu)遍歷數(shù)組;
2使用list()函數(shù)遍歷數(shù)組,list()函數(shù)僅能用于數(shù)字索引的數(shù)組,且數(shù)字索引從0開始。
例:綜合使用list()和each()認(rèn)證用戶登錄:
?php
//輸出用戶登錄信息
while(list($name,$value)=each($_POST)){
if($name!="submit"){
echo "$name=$valuebr";
}
}
?
七、統(tǒng)計數(shù)組元素個數(shù)
在PHP中,使用count()函數(shù)對數(shù)組中的元素個數(shù)進(jìn)行統(tǒng)計,語法為:int coun(mixed array[,int mode]),其中參數(shù)array為必要參數(shù),mode為可選參數(shù),若選中COUNT——RECURSIVE(或1),本函數(shù)將遞歸地對數(shù)組數(shù)組。如,
?php
$array = array("php" = array("PHP函數(shù)參考大全","PHP程序開發(fā)范例寶典","PHP數(shù)據(jù)庫系統(tǒng)開發(fā)完全手冊"),
"asp" = array("ASP經(jīng)驗技巧寶典")
); //聲明一個二維數(shù)組
echo count($array,COUNT_RECURSIVE);//遞歸統(tǒng)計數(shù)組元素的個數(shù),運行結(jié)果為6
?
八、數(shù)組排序
1使用sort()和rsort()分別對數(shù)組進(jìn)行升序和降序,如,
?php
$array=array(5,26,37,18,9,42,88,66);
$array1=sort($array);
for($i=0;$icount($array);$i++){
echo $array[$i]."??";
}
echo "br";
$array1=rsort($array);
for($i=0;$icount($array);$i++){
echo $array[$i]."?nbsp";
}
?
運行結(jié)果:
5 9 18 26 37 42 66 88
88 66 42 37 26 18 9 5
2使用ksort()和asort()對關(guān)聯(lián)數(shù)組排序
如果使用了相關(guān)數(shù)組,在排序后還要保持關(guān)鍵字和值的排序一致,這是就需要使用ksort()和asort()函
數(shù),如,
?php
$array=array('php'=1,'jsp'=2,'asp'=3);
ksort($array);
print_r($array);
echo "br";
asort($array);
print_r($array);
?
運行結(jié)果:
Array ( [asp] = 3 [jsp] = 2 [php] = 1 )
Array ( [php] = 1 [jsp] = 2 [asp] = 3 )
$sql = "SELECT * FROM log WHERE uid='$uid';"
$result = mysql_query($sql); //執(zhí)行返回的result ID
$arr[] = array(); //接收結(jié)果的數(shù)組
while( $row = mysql_fetch_assoc($result) ) $arr[]=$row; //存入數(shù)組
var_dump($arr);
樓上的
“$jg=mysql_query(你的sql語句);
while($icount($jg)) ” 這里的$jg 是返回的mysql的一個執(zhí)行ID 并不是數(shù)據(jù)數(shù)組 所以不能用count