PHP/MySQL3日通-第二天(一)
發(fā)表時間:2024-06-05 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]一、 while循環(huán) 在這一課里,我們將會繼續(xù)深入下去,使用PHP和MySQL來寫出一些簡單而有用的頁面。我們從昨天創(chuàng)建的數(shù)據(jù)庫開始,顯示庫中的數(shù)據(jù),但是會再稍微加以潤色。 首先,我們用下面的代碼來查詢數(shù)據(jù)庫內(nèi)容。 您可能已經(jīng)注意到,我們在這個程序里加進了一些新東西。最明顯的是whil...
一、 while循環(huán)
在這一課里,我們將會繼續(xù)深入下去,使用PHP和MySQL來寫出一些簡單而有用的頁面。我們從昨天創(chuàng)建的數(shù)據(jù)庫開始,顯示庫中的數(shù)據(jù),但是會再稍微加以潤色。
首先,我們用下面的代碼來查詢數(shù)據(jù)庫內(nèi)容。
您可能已經(jīng)注意到,我們在這個程序里加進了一些新東西。最明顯的是while()循環(huán)。該循環(huán)是說,只要數(shù)據(jù)庫里還有記錄可讀(使用mysql_fetch_row()函數(shù)),那就把該記錄賦給變量$myrow,然后執(zhí)行大括號({})內(nèi)的指令。仔細看一下這里,這部分是比較重要的。
我們應(yīng)該注意一下mysql_fetch_row()函數(shù)。這里有一點小問題,它返回的是一個數(shù)組,必須以數(shù)組下標來訪問其中的某個字段。第一個字段下標為0,第二個是1,依此類推。在執(zhí)行某些復(fù)雜查詢時,這么做簡直實在是太煩瑣了。
現(xiàn)在我們更仔細地研究一下循環(huán)過程。程序前幾行我們在第一課的例子中已經(jīng)看到過了。然后,在while()循環(huán)中,我們從查詢結(jié)果中讀取一條記錄并把該記錄賦給數(shù)組$myrow。接著,我們用printf函數(shù)把數(shù)據(jù)中的內(nèi)容顯示在屏幕上。隨后,循環(huán)反復(fù)執(zhí)行,讀取下一條記錄賦給$myrow。這樣繼續(xù)下去,直到所有記錄都已被讀取完為止。
使用while()循環(huán)? 個好處是,如果數(shù)據(jù)庫查詢沒有返回任何記錄,那您也不會收到錯誤信息。在剛執(zhí)行循環(huán)語句時,循環(huán)條件就不滿足,不會有任何數(shù)據(jù)賦給$myrow,程序就直接往下運行了。
但是如果查詢未返回任何數(shù)據(jù),我們怎么讓用戶知道這一點呢?我們也許該提供點兒相關(guān)的消息給用戶吧。這是可以做到的,下面我們就看看怎么做。
二、 if-else
請看下面的程序。
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
$db = mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
$result = mysql_query("SELECT * FROM employees",$db);
if ($myrow = mysql_fetch_array($result)) {
echo "$#@60;table border=1$#@62;\n";
echo "$#@60;tr$#@62;$#@60;td$#@62;姓名$#@60;/td$#@62;$#@60;td$#@62;住址$#@60;/td$#@62;$#@60;/tr$#@62;\n";
do {
printf("$#@60;tr$#@62;$#@60;td$#@62;%s %s$#@60;/td$#@62;$#@60;td$#@62;%s$#@60;/tr$#@62;\n", $myrow["first"], $myrow["last"], $myrow["address"]);
} while ($myrow = mysql_fetch_array($result));
echo "$#@60;/table$#@62;\n";
} else {
echo "對不起,沒有找到記錄!";
}
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62;
|
這段程序中包含有不少新內(nèi)容,不過這些內(nèi)容都相當簡單。首先是mysql_fetch_array()函數(shù)。該函數(shù)與mysql_fetch_row()十分相近,只有一點不同:使用這個函數(shù)時,我們可以通過字段名而不是數(shù)組下標來訪問它返回的字段,比如$myrow["first"]。這樣我們就可以省不少力氣了。另外,程序中還加進了do/while循環(huán)和if-else條件判定語句。
if-else條件判定語句的含意是,如果我們成功地把一條記錄賦給了$myrow變量,那就繼續(xù);否則,就跳到else部分,執(zhí)行那里的指令。
do/while循環(huán)是我們在上頁中用戶的while()循環(huán)的一個變體。我們要用到do/while的原因是:在最初的if語句中,我們已經(jīng)把查詢返回的第一條記錄賦給變量$myrow了。如果這時我們執(zhí)行一般的while循環(huán)(比如,while ($myrow = mysql_fetch_row($result)),那我們就會把第二條記錄賦給$myrow,而第一條記錄就被沖掉了。但是do/while循環(huán)可以讓我們執(zhí)行一次循環(huán)體內(nèi)容之后再來判定循環(huán)條件。因此,我們就不會不小心漏掉第一條記錄了。
最后,如果查詢結(jié)果沒有任何記錄的話,程序就會執(zhí)行包含在else{}部分的那些語句。如果您想看到這部分程序的執(zhí)行情況,可以把SQL語句改為SELECT * FROM employees WHERE id=6,或改成其他形式,使得查詢結(jié)果中沒有任何記錄。
下面我們來擴充一下循環(huán)if-else 代碼,使得頁面內(nèi)容更加豐富。相信您會喜歡的。
[page_break]
三、 第一個程序腳本
我們剛剛學(xué)到了循環(huán)語句,下面我們將在一個更加實際一點的例子中看看如何運用它。但是在這之前,您應(yīng)該知道如何處理Web表格、查詢參數(shù)串,以及表單的GET方法和POST方法。
現(xiàn)在,我們要處理查詢參數(shù)串,正如您所知道的,有三種方法可以把參數(shù)內(nèi)容寫入到查詢參數(shù)串中。第一種是在表格中使用GET方法;第二種是在瀏覽器的地址欄中輸入網(wǎng)址時直接加上查詢參數(shù);第三種是把查詢參數(shù)串嵌入到網(wǎng)頁的超鏈接中,使得超鏈接的內(nèi)容象下面這樣:$#@60;a href="http://my_machine/mypage.php3?id=1"$#@62;。我們現(xiàn)在要用到最后這一種方法。
一開始,我們再來查詢我們的數(shù)據(jù)庫,列出員工姓名。看看下面的程序,其中大部分內(nèi)容我們都已經(jīng)很熟悉了。
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
$db = mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
$result = mysql_query("SELECT * FROM employees",$db);
if ($myrow = mysql_fetch_array($result)) {
do {
printf("$#@60;a href=\"%s?id=%s\"$#@62;%s %s$#@60;/a$#@62;$#@60;br$#@62;\n", $PATH_INFO, $myrow["id"], $myrow["first"], $myrow["last"]);
} while ($myrow = mysql_fetch_array($result));
} else {
echo "對不起,沒有找到記錄!";
}
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62;
|
這里沒什么特別的,只是printf函數(shù)有些不同。那我們就來仔細研究一下。
首先要注意的是,所有的引號前面都有一個反斜杠。這個反斜杠告訴PHP直接顯示后面的字符,而不能把后面的字符當作程序代碼來處理。另外要注意變量$PATH_INFO的用法。該變量在所用程序中都可以訪問,是用來保存程序自身的名稱與目錄位置的。我們之所以用到它是因為要在頁面中再調(diào)用這個程序本身。使用$PATH_INFO,我們可以做到,即使程序被挪到其他目錄,甚至是其他機器上時,我們也能保證正確地調(diào)用到這個程序。
正如我剛才提到的,程序所生成的網(wǎng)頁,其中包含的超鏈接會再次調(diào)用程序本身。不過,再次調(diào)用時,會加入一些查詢參數(shù)。
PHP見到查詢參數(shù)串中包含有“名字=值”這樣的成對格式時,會作一些特別的處理。它會自動生成一個變量,變量名稱與取值都與查詢參數(shù)串中所給定的名稱和取值相同。這一功能使得我們可以在程序中判斷出是第一次執(zhí)行本程序還是第二次。我們所要做的只是問問PHP$id這個變量是否存在。
當我知道這個問題的答案后,我可以在第二次調(diào)用程序時顯示一些不同的結(jié)果出來。請看:
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
$db = mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
// display individual record // 顯示單條記錄內(nèi)容
if ($id) {
$result = mysql_query("SELECT * FROM employees WHERE id=$id",$db);
$myrow = mysql_fetch_array($result);
printf("名: %s\n$#@60;br$#@62;", $myrow["first"]);
printf("姓: %s\n$#@60;br$#@62;", $myrow["last"]);
printf("住址: %s\n$#@60;br$#@62;", $myrow["address"]);
printf("職位: %s\n$#@60;br$#@62;", $myrow["position"]);
} else {
// show employee list // 顯示員工列表
$result = mysql_query("SELECT * FROM employees",$db);
if ($myrow = mysql_fetch_array($result)) {
// display list if there are records to display // 如果有記錄,則顯示列表
do {
printf("$#@60;a href=\"%s?id=%s\"$#@62;%s %s$#@60;/a$#@62;$#@60;br$#@62;\n", $PATH_INFO, $myrow["id"], $myrow["first"], $myrow["last"]);
} while ($myrow = mysql_fetch_array($result));
} else {
// no records to display // 沒有記錄可顯示
echo "對不起,沒有找到記錄!";
}
}
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62;
|
程序開始變得復(fù)雜了,所以我在這里面加了注釋,來解釋一下到底發(fā)生了什么。您可以用//加入單行注釋,或者用/*和*/來括住大段的注釋。
到這里,我們已經(jīng)學(xué)會了第一個真正有用的PHP/MySQL腳本程序!現(xiàn)在,我們要看看怎樣把Web表格加進來,并且向數(shù)據(jù)庫發(fā)送數(shù)據(jù)。