PHP數(shù)組的總結(jié)(很全面啊)
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:空間域名、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、洛浦網(wǎng)站維護(hù)、網(wǎng)站推廣。
一、什么是數(shù)組
數(shù)組就是一組數(shù)據(jù)的集合,把一系列數(shù)據(jù)組織起來,形成一個可操作的整體。數(shù)組的每個實(shí)體都包含兩項(xiàng):鍵和值。
二、聲明數(shù)據(jù)
在PHP中聲明數(shù)組的方式主要有兩種:一是應(yīng)用array()函數(shù)聲明數(shù)組,一是直接為數(shù)組元素賦值。
1array()函數(shù)聲明的數(shù)
一、什么是數(shù)組
數(shù)組就是一組數(shù)據(jù)的集合,把一系列數(shù)據(jù)組織起來,形成一個可操作的整體。數(shù)組的每個實(shí)體都包含兩項(xiàng):鍵和值。
二、聲明數(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í)際編寫程序時數(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語句來實(shí)現(xiàn),但這只能對數(shù)組中某一元素進(jìn)行輸出;要將數(shù)組結(jié)構(gòu)輸出則要使用print_r()函數(shù),其語法:print_r(mixed
expression),參數(shù)expression為普通的整形、字符型或?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"),
"體育項(xiàng)目"=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)計(jì)數(shù)組元素個數(shù)
在PHP中,使用count()函數(shù)對數(shù)組中的元素個數(shù)進(jìn)行統(tǒng)計(jì),語法為: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)驗(yàn)技巧寶典")
);
//聲明一個二維數(shù)組
echo
count($array,COUNT_RECURSIVE);//遞歸統(tǒng)計(jì)數(shù)組元素的個數(shù),運(yùn)行結(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";
}
?
運(yùn)行結(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);
?
運(yùn)行結(jié)果:
Array
(
[asp]
=
3
[jsp]
=
2
[php]
=
1
)
Array
(
[php]
=
1
[jsp]
=
2
[asp]
=
3
)
SELECT SUM(分?jǐn)?shù)) FROM 表a WHERE 性別='男'
SELECT SUM(分?jǐn)?shù)) FROM 表a WHERE 性別='女'
----測試
CREATE TABLE MASK_TEST(
ID INT,
姓名 varchar(20),
性別 varchar(20),
年齡 int,
分?jǐn)?shù) int
)
INSERT INTO MASK_TEST VALUES(11,'ZHANG SAN','男',20,88)
INSERT INTO MASK_TEST VALUES(11,'LIU SHAN','女',20,83)
INSERT INTO MASK_TEST VALUES(11,'WANG SAN','男',20,87)
INSERT INTO MASK_TEST VALUES(11,'ZHANG TING','女',20,83)
INSERT INTO MASK_TEST VALUES(11,'ZHAO YAN','女',20,88)
INSERT INTO MASK_TEST VALUES(11,'ZHOU HU','男',20,78)
INSERT INTO MASK_TEST VALUES(11,'WANG QIANG','男',20,98)
INSERT INTO MASK_TEST VALUES(11,'LI QIAN','女',21,68)
SELECT SUM(分?jǐn)?shù)) FROM MASK_TEST WHERE 性別='男'
SELECT SUM(分?jǐn)?shù)) FROM MASK_TEST WHERE 性別='女'
----結(jié)果:
(1 行受影響)
(1 行受影響)
(1 行受影響)
(1 行受影響)
(1 行受影響)
(1 行受影響)
(1 行受影響)
(1 行受影響)
-----------
351
(1 行受影響)
-----------
322
(1 行受影響)
php+mysql,
舉個例子
...........省略數(shù)據(jù)庫連接3步驟
$sql
=
"select
sum(price)
from
table";
//查詢price字段下所有值的和
$query
=
mysql_query($sql);
//執(zhí)行sql語句
$result
=
mysql_fetch_row($query);
//取得搜索結(jié)果中的數(shù)據(jù)(一個數(shù)組)
echo
$result[0];
//
數(shù)組中只有一條數(shù)據(jù),所以索引
就可以了
echo就是顯示啦,
希望能幫到你
可以直接使用mysql的sum函數(shù)求和,mysql會自動轉(zhuǎn)換為數(shù)字型進(jìn)行求和.