天極網
創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供通榆網站建設、通榆做網站、通榆網站設計、通榆網站制作等企業(yè)網站建設、網頁設計與制作、通榆企業(yè)網站模板建站服務,十余年通榆做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
《PHP新手上路全教程》
《PHP編程常用技巧》
《PHP+MySQL網絡開發(fā)技術》
《PHP4.0 Web 開發(fā)技術指南》
《PHP4.0編程指南與樣例》
《PHP實例程序》
《PHP專業(yè)基礎教程》
《PHP 核心編程所有例程》
《PHP4交互式網頁數據庫實戰(zhàn)手冊》
《PHP 5 揭密 》
《PHP Apache 和 MySQL 網頁開發(fā)初步》
《PHPMORE 第三期》
《專業(yè)PHP4編程》
《整合PHP和XML》
《PHP 4.0與架構Web數據庫》
《PHP4完全中文手冊》
PHP調用三種數據庫的方法
本文比較詳細的介紹PHP調用MySQL、ODBC以及ORACLE數據庫。
MySQL是一個小巧靈瓏的數據庫服務器軟件,對于中、小型應用系統(tǒng)是非常理想的。除了支持標準的ANSI SQL語句外,最重要的是,它還支持多種平臺,而在Unix/Linux系統(tǒng)上,MySQL支持多線程運行方式,從而能獲得相當好的性能。它和PHP、 Apache一樣,是屬于開放源代碼軟件。其官方網站是:,上面提供Windows,Linux,Unix版本的源代碼的下載。
注意,MySQL訪問函數都需要有相應的權限才能運行。常用的相關函數介紹如下:
(1)integer mysql_connect(主機,用戶名,口令);
此函數開始一個對指定主機上的MySQL數據庫的連接。若該數據庫位于一個不同地端口,則在主機名后加上冒號和端口號。所有參數均為可選的,缺省情況下分別對應為本地主機、用戶正在執(zhí)行的腳本名和空。主機可以是IP地址或域名。
在腳本執(zhí)行結束時,連接被自動關閉,也可以用mysql_close提前關閉。
(2)boolean mysql_create_db(數據庫名);
創(chuàng)建一個數據庫。注意必須用一個帶有創(chuàng)建數據庫許可權的帳號打開連接。
(3)boolean mysql_select_db(數據庫名,連接號);
選擇缺省數據庫。
(4)integer mysql_query(SQL語句,連接號);
對指定數據庫進行查詢。如果SQL語句是select,則返回一個結果號,否則返回的值可以不理會。如果失敗,返回false.。
(5)array mysql_fetch_array(結果號);
取出下一行,返回一個數組.可以用數字下標訪問(第一個字段是下標 0),也可以用字符串下標訪問(即使用各字段名)。如已取了最后一行,返回 false.。
(6)mysql_fetch_row(結果號);
返回一個矩陣代表結果集中一行的所有域。每次調用都會產生下一行,直到沒有行剩下時返回false。每個域值都由一個從零開始的偏移量索引。這是從查詢中獲取結果的最快方法。
(7)integer mysql_num_rows(結果號);
返回結果集中行的數目
(8)integer mysql_num_fields(結果號);
返回結果集中域的數目。
(9)integer mysql_list_dbs();
向服務器查詢數據庫列表。它返回一個結果指針,該指針可用于mysql_fetch_row函數及類似函數。
(10)mysql_list_tables(數據庫名);
獲取一個指向指定數據庫的表單列表的結果指針。該結果指針可用于任何從結果集中獲取行的函數。
(11)mysql_close(連接號);
關閉對數據庫的連接。連接必須是由mysql_connect打開的。該函數的使用不是嚴格必需的,因為在腳本結束時,所有非永久鏈路都會被自動關閉。
(12)mysql_pconnect(主機,用戶名,口令);
與mysql_connect完全相似,但建立一個"永久連接",該連接一經建立永不關閉,即使使用mysql_close函數或程序執(zhí)行完畢也不關閉.下一次試圖建立永久連接時,系統(tǒng)如發(fā)現(xiàn)已存在一個永久連接,則直接返回該連接號而不重新創(chuàng)建。
下面是一個調用MYSQL數據庫并分頁顯示的例子。
?
$pagesize = 5; //每頁顯示5條記錄
$host="localhost";
$user="user";
$password="psw";
$dbname="book"; //所查詢的庫表名;
//連接MySQL數據庫
mysql_connect("$host","$user","$password") or die("無法連接MySQL數據庫服務器!");
$db = mysql_select_db("$dbname") or die("無法連接數據庫!");
$sql = "select count(*) as total from pagetest";//生成查詢記錄數的SQL語句
$rst = mysql_query($sql) or die("無法執(zhí)行SQL語句:$sql !"); //查詢記錄數
$row = mysql_fetch_array($rst) or die("沒有更多的記錄!"); /取出一條記錄
$rowcount = $row["total"];//取出記錄數
mysql_free_result($rst) or die("無法釋放result資源!"); //釋放result資源
$pagecount = bcdiv($rowcount+$pagesize-1,$pagesize,0);//算出總共有幾頁
if(!isset($pageno)) {
$pageno = 1; //在沒有設置pageno時,缺省為顯示第1頁
}
if($pageno1) {
$pageno = 1; //若pageno比1小,則把它設置為1
}
if($pageno$pagecount) {
$pageno = $pagecount; //若pageno比總共的頁數大,則把它設置為最后一頁
}
if($pageno0) {
$href = eregi_replace("%2f","/",urlencode($PHP_SELF));//把$PHP_SELF轉換為可以在URL上使用的字符串,這樣的話就可以處理中文目錄或中文文件名
if($pageno1){//顯示上一頁的褳接
echo "a href="" . $href . "?pageno=" . ($pageno-1) . ""上一頁/a ";
}
else{
echo "上一頁";
}
for($i=1;$i$pageno;$i++){
echo "a href="" . $href . "?pageno=" . $i . """ . $i . "/a ";
}
echo $pageno . " ";
for($i++;$i=$pagecount;$i++){
echo "a href="" . $href . "?pageno=" . $i . """ . $i . "/a ";
}
if($pageno$pagecount){//顯示下一頁的褳接
echo "a href="" . $href . "?pageno=" . ($pageno+1) . ""下一頁/a ";
}
else{
echo "下一頁 ";
}
$offset = ($pageno-1) * $pagesize;//算出本頁第一條記錄在整個表中的位置(第一條記錄為0)
$sql = "select * from pagetest LIMIT $offset,$pagesize";//生成查詢本頁數據的SQL語句
$rst = mysql_query($sql);//查詢本頁數據
$num_fields = mysql_num_fields($rst);//取得字段總數
$i = 0;
while($i$num_fields){//取得所有字段的名字
$fields[$i] = mysql_field_name($rst,$i);//取得第i+1個字段的名字
$i++;
}
echo "table border="1" cellspacing="0" cellpadding="0"";//開始輸出表格
echo "tr";
reset($fields);
while(list(,$field_name)=each($fields)){//顯示字段名稱
echo "th$field_name/th";
}
echo "/tr";
while($row=mysql_fetch_array($rst)){//顯示本頁數據
echo "tr";
reset($fields);
while(list(,$field_name)=each($fields)){//顯示每個字段的值
$field_value = $row[$field_name];
if($field_value==""){
echo "td /td";
}
else{
echo "td$field_value/td";
}
}
echo "/tr";
}
echo "/table";//表格輸出結束
mysql_free_result($rst) or die("無法釋放result資源!");//釋放result資源
}
else{
echo "目前該表中沒有任何數據!";
}
mysql_close($server) or die("無法與服務器斷開連接!");//斷開連接并釋放資源
?
開放數據庫連接(ODBC)已成為一種與數據庫進行通信的工業(yè)標準。PHP也提供了標準的接口,使得PHP能調用Access,SQL SERVER等數據庫。其相關函數是:
(1)integer odbc_connect(string dsn, string user, string password)
連接到一個ODBC數據庫源名字上。
(2)integer odbc_exec(integer connection, string query)或 odbc_do(integer connection, string query)
在一個連接上執(zhí)行查詢。
(3)boolean odbc_fetch_row(integer result, integer row)
從一個結果集中獲取一行數據。Row參數是可選的,若為空缺,則返回下一個有效行。在結果集中不再剩余行時返回false。
(4)boolean odbc_close(integer connection)
關閉一個數據庫的連接。若在該連接上有打開的事務,則返回一個錯誤,而且連接不會被關閉。
最后,還是看個分頁的例子:
?
//設定每頁顯示條數
$show_num = 10;
$spages = $pages;//避免$pages后期被改變
//定義連接
$dsn = "localhost";
$user = "sa";
$password = "";
//計算總記錄數
$rs_num = "select count(*) as id from bbs where zu='0' and lei='".$lei."'";
$conn_id = odbc_connect($dsn,$user,$password);
$rnum = odbc_exec($conn_id,$rs_num);
while(odbc_fetch_row($rnum)){
$total_rs = odbc_result($rnum,"id");//將總記錄數放入$total_rs變量
}
//計算與頁有關的條數
$nnn = $total_rs / $show_num;//計算總頁數
$hnnn = intval($nnn);//將總頁數取整
$cnnnn = $nnn - $hnnn;
//計算所需總頁數
switch ($cnnn){
case "0":
$hnnn++;
$nnn = $hnnn;//總頁數
break;
default :
$nnn = $hnnn;//總頁數
break;
};
if ($nnn == 0)$nnn++;
//計算頁面改變所需的條件
$fore = $pages;
$next = $pages;
$fore -= 1;
$next += 1;
if ($fore 0) {
echo "a首頁/a";
echo "a前頁/a";
};
if ($pages $nnn) {
echo "a后頁/a";
echo "a尾頁/a";
};
echo "共".$nnn."頁";
$query_string = "SELECT * FROM table where condition order by you wanted order";
$cur = odbc_exec($conn_id,$query_string);
//取到循環(huán)的頂部
$cnum = ($pages-1) * $show_num;//計算當前的記錄游標的位置
//空循環(huán)到顯示記錄游標處
if ($cnum != 0){
for ($i=0;$i=$cnum;odbc_fetch_row($cur));
};
$i=1;
//顯示記錄
while(odbc_fetch_row($cur)){
echo ;
if ($i == $show_num){//在不滿頁數時跳出程序
break;
};
$i++;
};
//關閉連接
odbc_close($conn_id);
?
Oracle(甲骨文)是世界上最為流行的關系數據庫。它是大公司推崇的工業(yè)化的強有力的引擎。我們先看看其相關的函數:
(1)integer ora_logon(string user , string password)
開始對一個Oracle數據庫服務器的連接。
(2)integer ora_open(integer connection)
打開給出的連接的游標。
(3)integer ora_do(integer connection, string query)
在給出的連接上執(zhí)行查詢。PHP生成一個指示器,解析查詢,并執(zhí)行之。
(4)integer ora_parse(integer cursor, string query)
解析一個查詢并準備好執(zhí)行。
(5)boolean ora_exec(integer cursor)
執(zhí)行一個先前由ora_parse函數解析過的查詢。
(6)boolean ora_fetch(integer cursor)
此函數會使得一個執(zhí)行過的查詢中的行被取到指示器中。這使得您可以調用ora_getcolumn函數。
(7)string ora_getcolumn(integer cursor, integer column)
返回當前的值。列由零開始的數字索引。
(8)boolean ora_logoff(integer connection)
斷開對數據庫服務器的鏈接。
以下是向ORACLE數據庫插入數據的示例程序:
html
headtitle向ORACLE數據庫中插入數據/title/head
body
form action="?echo $PHP_SELF;?" method="post"
table border="1" cellspacing="0" cellpadding="0"
tr
thID/th
thname/th
thDescription/th
/tr
tr
tdinput type="text" name="name" maxlength="50" size="10"/td
tdinput type="text" name="email" maxlength="255" size="30"/td
tdinput type="text" name="Description" maxlength="255" size="50"/td
/tr
tr align="center"
td colspan="3"input type="submit" value="提交"??input type="reset" value="重寫"/td
/tr
/table
/form
?
//先設置兩個環(huán)境變量ORACLE_HOME,ORACLE_SID
putenv("ORACLE_HOME=/oracle/app/oracle/product/8.0.4");
putenv("ORACLE_SID=ora8");
//設置網頁顯示中文
putenv("NLS_LANG=Simplified_Chinese.zhs16cgb231280");
if($connection=ora_logon("scott","tiger")) {
//庫表test有ID,name,Description三項
$sql = 'insert into test(ID,name,Description) values ';
$sql .= '('' . $ID . '','' . $name . '',''. $Description . '')';
if($cursor=ora_do($connect,$sql)) {
print("insert finished!");
}
$query = 'select * from test';
if($cursor=ora_do($connect,$query)) {
ora_fetch($cursor);
$content0=ora_getcolumn($cursor,0);
$content1=ora_getcolumn($cursor,1);
$content2=ora_getcolumn($cursor,2);
print("$content0");
print("$content1");
print("$content2");
ora_close($cursor);
}
ora_logoff($connection);
}
?
/body
/html
通過PHP你可以輕松的連接到數據庫,請求數據并將其顯示在你的web站點中,甚至修改數據庫中的數據。 MySQL是一種很流行的數據庫,并且在互聯(lián)網中有許多有關PHP與MySQL的教程。MySQL是免費的,這一點也許就吸引了不少人。由于其廣泛應用, 我就不想在這里贅述MySQL的使用方法了。Oracle被大量在企業(yè)應用中采用,因此我們就利用Oracle來介紹PHP與數據庫的連接。我們當然不會 提及Oracle數據庫的設計原理,原因是這已經超出了我們的討論范圍。
PHP提供了兩套函數與Oracle連接,分別是ORA_和OCI函數。其中ORA_函數略顯陳舊。OCI函數更新?lián)f更好一些。兩者的使用語法幾乎相差無幾。如前所述,你的PHP安裝選項應該可以支持兩者的使用。
想獲得更多有關在Microsoft Windows平臺上安裝支持PHP3的Apache服務器的知識以及更多有關Oracle數據庫的知識,請查閱以下URL:。
4.1 連接
if ($conn=Ora_Logon("user@TNSNAME","password"))
{
echo "SUCCESS ! Connected to database\n";
}
else
{
echo "Failed :-( Could not connect to database\n";
}
Ora_Logoff($conn);
phpinfo();
?
以上代碼使用TNSNAME(在你的tnsnames.ora文件中指明)定義的Oracle數據庫名稱、用戶名稱和密碼連接數據庫。在成功連接的基礎上,ora_logon函數返回一個非零的連接ID并儲存在變量$conn中。
4.2 查詢
假設與數據庫已經連接就緒,下面我們就來實際的應用對數據庫的查詢。下面的代碼演示了一個連接并查詢的典型例子:
/*
* 連接數據庫并執(zhí)行查詢
*/
function printoraerr($in_cur)
{
// 檢查Oracle是否出錯
// 如果存在錯誤則顯示
// 當指針被激活時每次請求Oracle后調用該函數
if(ora_errorcode($in_cur))
echo "Oracle code - ".ora_error($in_cur)."\n";
return;
}
/** 主程序 */
if (!($conn=ora_logon("user@TNSNAME","password")))
{
echo "Connection to database failed\n";
exit;
}
echo "Connected as connection - $conn
\n";
echo "Opening cursor ...
\n";
$cursor=ora_open($conn); printoraerr($cursor);
echo "Opened cursor - $cursor
\n";
$qry="select user,sysdate from dual";
echo "Parsing the query $qry ...
\n";
ora_parse($cursor,$qry,0); printoraerr($cursor);
echo "Query parsed
\n";
echo "Executing cursor ...
\n";
ora_exec($cursor); printoraerr($cursor);
echo "Executed cursor
\n";
echo "Fetching cursor ...
\n";
while(ora_fetch($cursor))
{
$user=ora_getcolumn($cursor,0); printoraerr($cursor);
$sysdate=ora_getcolumn($cursor,1); printoraerr($cursor);
echo " row = $user, $sysdate
\n";
}
echo "Fetched all records
\n";
echo "Closing cursor ...
\n";
ora_close($cursor);
echo "Closed cursor
\n";
echo "Logging off from oracle...
\n";
ora_logoff($conn);
echo "Logged off from oracle
\n";
?
(譯者注:以上代碼段缺少注釋,請讀者參考PHP Manual的Oracle數據庫函數部分)
4.3 顯示結果
以下代碼演示了怎樣查詢數據庫并將結果輸出:
function printoraerr($in_cur, $conn)
{
// 檢查Oracle是否出錯
// 如果存在錯誤則顯示
// 當指針被激活時每次請求Oracle后調用該函數
// If it encountered an error, we exit immediately
if(ora_errorcode($in_cur))
{
echo "Oracle code - ".ora_error($in_cur)."
n";
ora_logoff($conn);
exit;
}
return;
}
function exequery($w_qry,$conn)
{
$cursor=ora_open($conn); printoraerr($cursor,$conn);
ora_parse($cursor,$w_qry,0); printoraerr($cursor,$conn);
ora_exec($cursor); printoraerr($cursor,$conn);
$numrows=0;
$w_numcols=ora_numcols($cursor);
// 顯示頭部
echo "
\n";
for ($i=0;$i$w_numcols;$i++)
{
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";
echo "\t ".ora_columnname($cursor,$i)." \n";
}
echo "
\n";
while(ora_fetch($cursor))
{
echo " \n";
for ($i=0;$i$w_numcols;$i++)
{
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";
if(ora_columntype($cursor,$i)=="LONG")
echo " ".
ora_getcolumn($cursor,$i)."
\n";
else
echo " ".ora_getcolumn($cursor,$i)." \n";
printoraerr($cursor,$conn);
}
$numrows++;
echo "
\n";
}
if ($numrows==0)
echo " Query returned no records
\n";
else
{
echo " \n";
echo " Count \n";
echo " $numrows \n";
echo "
\n";
}
echo " \n";
ora_close($cursor);
return;
}
// 主程序
if(!($conn=ora_logon("user@SID","password")))
{
echo "Error: Cannot connect to database\n";
exit;
}
$qry="SELECT
deptno \"Dept\"
,empno \"Emp\"
,empnm \"Name\"
,salary \"Salary\"
FROM
employee
ORDER BY 1,2";
exequery($qry);
ora_logoff($conn);
?
(譯者注:以上代碼段缺少注釋,請讀者參考PHP Manual的Oracle數據庫函數部分)
4.4 基于HTTP的Oracle登錄
將以下代碼加在PHP頁面代碼之前以確認Oracle登錄。注意你必須正確設定$ SID。
if(!isset($PHP_AUTH_USER))
{
Header("WWW-authenticate: basic realm=\"$SID\"");
Header("HTTP/1.0 401 Unauthorized");
$title="Login Instructions";
echo "
You are not authorized to enter the site
\n";
exit;
}
else
{
if (!($conn=ora_logon("$PHP_AUTH_USER@$SID",$PHP_AUTH_PW)))
{
Header("WWW-authenticate: basic realm=\"$SID\"");
Header("HTTP/1.0 401 Unauthorized");
$title="Login Instructions";
echo "
You are not authorised to enter the site
\n";
exit;
}
}
?
PHP入門基礎教程大全
PHP于1994年由Rasmus Lerdorf創(chuàng)建,剛剛開始是Rasmus Lerdorf為了要維護個人網頁而制作的一個簡單的用Perl語言編寫的程序。這些工具程序用來顯示 Rasmus Lerdorf 的個人履歷,以及統(tǒng)計網頁流量。后來又用C語言重新編寫,包括可以訪問數據庫。他將這些程序和一些表單直譯器整合起來,稱為 PHP/FI。PHP/FI 可以和數據庫連接,產生簡單的動態(tài)網頁程序。為幫助大家入門學習php,我為大家分享PHP入門知識教程如下:
1、嵌入方法:
類似ASP的%,PHP可以是?php或者是?,結束符號是?,當然您也可以自己指定。
2、引用文件:
引用文件的方法有兩種:require 及 include。
require 的使用方法如 require("MyRequireFile.php"); 。這個函數通常放在 PHP 程序的最前面,PHP 程序在執(zhí)行前,就會先讀入 require 所指定引入的文件,使它變成 PHP 程序網頁的一部份。常用的函數,亦可以這個方法將它引入網頁中。
include 使用方法如 include("MyIncludeFile.php"); 。這個函數一般是放在流程控制的處理部分中。PHP 程序網頁在讀到 include 的文件時,才將它讀進來。這種方式,可以把程序執(zhí)行時的流程簡單化。
3、注釋方法:
?php
echo "這是第一種例子。\n" ; // 本例是 C++ 語法的注釋 (PHP的注釋跟C差不多?。?/p>
/* 本例采用多行的
注釋方式 */
echo "這是第二種例子。\n" ;
echo "這是第三種例子。\n" ; # 本例使用 UNIX Shell 語法注釋
?
4、變量類型:
$mystring = "我是字符串" ;
$NewLine = "換行了\n" ;
$int1 = 38 ;
$float1 = 1.732 ;
$float2 = 1.4E+2 ;
$MyArray1 = array( "子" , "丑" , "寅" , "卯" );
這里引出兩個問題,首先PHP變量以$開頭,第二PHP語句以;結尾,可能ASP程序員會不適應。這兩個遺漏也是程序上大多錯誤所在。
5、運算符號:
數**非法字眼已被屏蔽**算:
符號 ? ? 意義
+ ? ? ? 加法運算
- ? ? ? ?減法運算
* ? ? ? ?乘法運算
/ ? ? ? ?除法運算
% ? ? ?取余數
++ ? ? 累加
-- ? ? ? 遞減
字符串運算:
運算符號只有一個,就是英文的句號。它可以將字符串連接起來,變成合并的新字符串。類似ASP中的
?
$a = "PHP 4" ;
$b = "功能強大" ;
echo $a.$b;
?
這里也引出兩個問題,首先PHP中輸出語句是echo,第二類似ASP中的%=變量%,PHP中也可以?=變量?。
邏輯運算:
符號 意義
小于
大于
= 小于或等于
= 大于或等于
== 等于
!= 不等于
而且 (And)
and 而且 (And)
或者 (Or)
or 或者 (Or)
xor 異或 (Xor)
! 不 (Not)
學習目的:掌握php的流程控制
1、if..else 循環(huán)有三種結構
第一種是只有用到 if 條件,當作單純的判斷。解釋成 "若發(fā)生了某事則怎樣處理"。語法如下:
if (expr) { statement }
其中的 expr 為判斷的條件,通常都是用邏輯運算符號當判斷的條件。而 statement 為符合條件的執(zhí)行部分程序,若程序只有一行,可以省略大括號 {}。
范例:本例省略大括號。
?php
if ($state==1)echo "哈哈" ;
?
這里特別注意的是,判斷是否相等是==而不是=,ASP程序員可能常犯這個錯誤,= 是賦值。
范例:本例的執(zhí)行部分有三行,不可省略大括號。
?php
if ($state==1) {
echo "哈哈 ;
echo "br" ;
}
?
第兩種是除了 if 之外,加上了 else 的條件,可解釋成 "若發(fā)生了某事則怎樣處理,否則該如何解決"。語法如下
if (expr) { statement1 } else { statement2 } 范例:上面的例子來修改成更完整的處理。其中的 else 由于只有一行執(zhí)行的指令,因此不用加上大括號。
?php
if ($state==1) {
echo "哈哈" ;
echo "br";
}
else{
echo "呵呵";
echo "br";
}
?
第三種就是遞歸的 if..else 循環(huán),通常用在多種決策判斷時。它將數個 if..else 拿來合并運用處理。
直接看下面的例子
?php
if ( $a $b ) {
echo "a 比 b 大" ;
} elseif ( $a == $b ) {
echo "a 等于 b" ;
} else {
echo "a 比 b 小" ;
}
?
上例只用二層的 if..else 循環(huán),用來比較 a 和 b 兩個變量。實際要使用這種遞歸 if..else 循環(huán)時,請小心使用,因為太多層的循環(huán)容易使設計的邏輯出問題,或者少打了大括號等,都會造成程序出現(xiàn)莫名其妙的問題。
2、 for 循環(huán)就單純只有一種,沒有變化,它的語法如下
for (expr1; expr2; expr3) { statement }
其中的 expr1 為條件的`初始值。expr2 為判斷的條件,通常都是用邏輯運算符號 (logical operators) 當判斷的條件。expr3 為執(zhí)行 statement 后要執(zhí)行的部份,用來改變條件,供下次的循環(huán)判斷,如加一..等等。而 statement 為符合條件的執(zhí)行部分程序,若程序只有一行,可以省略大括號 {}。
下例是用 for 循環(huán)寫的的例子。
?php
for ( $i = 1 ; $i = 10 ; $i ++) {
echo "這是第".$i."次循環(huán)br" ;
}
?
3、 switch 循環(huán),通常處理復合式的條件判斷,每個子條件,都是 case 指令部分。在實作上若使用許多類似的 if 指令,可以將它綜合成 switch 循環(huán)。
語法如下
switch (expr) { case expr1: statement1; break; case expr2: statement2; break; default: statementN; break; }
其中的 expr 條件,通常為變量名稱。而 case 后的 exprN,通常表示變量值。冒號后則為符合該條件要執(zhí)行的部分。注意要用 break 跳離循環(huán)。
?php
switch ( date ( "D" )) {
case "Mon" :
echo "今天星期一" ;
break;
case "Tue" :
echo "今天星期二" ;
break;
case "Wed" :
echo "今天星期三" ;
break;
case "Thu" :
echo "今天星期四" ;
break;
case "Fri" :
echo "今天星期五" ;
break;
default:
echo "今天放假" ;
break;
}
?
這里需要注意的是break;別遺漏了,default,省略是可以的。
很明顯的,上述的例子用 if 循環(huán)就很麻煩了。當然在設計時,要將出現(xiàn)機率最大的條件放在最前面,最少出現(xiàn)的條件放在最后面,可以增加程序的執(zhí)行效率。上例由于每天出現(xiàn)的機率相同,所以不用注意條件的順序。
學會構建數據庫
在PHP中,MY SQL的命令行編輯可能會令初學者感到很麻煩,不要緊,你下載一個PHPMYADMIN安裝一下,以后建立編輯數據庫可以靠它了。
下面說一下它的使用。
進入了phpmyadmin后,我們首先需要建立一個數據庫,
Language (*) 這里選擇中文簡體,然后在左邊的 創(chuàng)建一個新的數據庫 這里填寫數據庫名字,點擊創(chuàng)建即可。
然后在左邊下拉菜單中選擇那個已經創(chuàng)建的數據庫。在下面的
在數據庫 shop 中創(chuàng)建一個新表 :
名字 :
字段數 :
中填寫表名字和大致你認為的字段數(不夠或者多了都不要緊,以后可以再添加或者缺?。?,按執(zhí)行。
然后就可以開始建立表了。
第一欄是字段的名字;第二欄選擇字段類型:
我們常用的是以下幾個:
1)VARCHAR,文本類型
2)INT,整數類型
3)FLOAT,浮點數類型
4)DATE,日期型
5)大家或許會問,自動添加的ID在哪里?這個只要選擇INT類型,在后面的額外中選擇 auto_increment 就可以了。
建立了表以后,可以在左邊看到你建立的表,點擊以后,你可以:
1)按右邊的結構:查看修改表結構
2)按右邊的瀏覽:查看表中的數據
3)按右邊的SQL:運行SQL語句
4)按右邊的插入:插入一行記錄
5)按右邊的清空:刪除表中所有記錄
6)按右邊的刪除:刪除表
還有一個很重要的功能就是導入和導出,當我們本機做好了程序和數據庫的時候,需要在服務器上也有一個本地鏡像,如果是ASP的ACCESS簡單了,直接上傳MDB文件即可,如果是SQL SERVER也可以連接遠端服務器進行導入。那么MY SQL中你可以導出所有的SQL語句,到了遠端服務器的PHPMYADMIN上,創(chuàng)建數據庫后按SQL,粘帖你剛才復制下來的所有本級生成的SQL語句即可。
學會連接數據庫
PHP簡直就是一個函數庫,豐富的函數使PHP的某些地方相當簡單。建議大家down一本PHP的函數手冊,總用的到。
我這里就簡單說一下連接MYSQL數據庫。
1、mysql_connect
打開 MySQL 服務器連接。
語法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整數
本函數建立與 MySQL 服務器的連接。其中所有的參數都可省略。當使用本函數卻不加任何參數時,參數 hostname 的默認值為 localhost、參數 username 的默認值為 PHP 執(zhí)行行程的擁有者、參數 password 則為空字符串 (即沒有密碼)。而參數 hostname 后面可以加冒號與端口號,代表使用哪個端口與 MySQL 連接。當然在使用數據庫時,早點使用 mysql_close() 將連接關掉可以節(jié)省資源。
2、 mysql_select_db
選擇一個數據庫。
語法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整數
本函數選擇 MySQL 服務器中的數據庫以供之后的資料查詢作業(yè) (query) 處理。成功返回 true,失敗則返回 false。
最簡單的例子就是:
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
連接機MY SQL數據庫,打開SHOP數據庫。在實際應用中應當加強點錯誤判斷。
學會讀取數據
先看兩個函數:
1、mysql_query
送出一個 query 字符串。 語法: int mysql_query(string query, int [link_identifier]); 返回值: 整數
本函數送出 query 字符串供 MySQL 做相關的處理或者執(zhí)行。若沒有指定 link_identifier 參數,則程序會自動尋找最近打開的 ID。當 query 查詢字符串是 UPDATE、INSERT 及 DELETE 時,返回的可能是 true 或者 false;查詢的字符串是 SELECT 則返回新的 ID 值,當返回 false 時,并不是執(zhí)行成功但無返回值,而是查詢的字符串有錯誤。
2、mysql_fetch_object 返回類資料。 語法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 類
本函數用來將查詢結果 result 拆到類變量中。若 result 沒有資料,則返回 false 值。
看一個簡單的例子:
?
$exec="select * from user";
$result=mysql_query($exec);
while($rs=mysql_fetch_object($result))
{
echo "username:".$rs-username."br";
}
?
當然,表user中有一個username的字段,這就類似asp中的
%
exec="select * from user"
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
do while not rs.eof
response.write "username:"rs("username")"br"
rs.movenext
loop
%
當然先要連接數據庫,一般我們 require_once('conn.php');而conn.php里面就是上一次說的連接數據庫的代碼。
小小的兩條命令可以完成讀取數據的工作了
學會添加刪除修改數據
mysql_query($exec);
單這個語句就可以執(zhí)行所有的操作了,不同的就是$exec這個sql語句
添加:$exec="insert into tablename (item1,item2) values ('".$_POST['item1']."',".$_POST['item1'].")";
刪除:$exec="delete from tablename where...";
修改:$exec="update tablename set item1='".$_POST['item1']."' where ...";
說到這里就要說一下表單和php變量傳遞,如果表單中的一個 input name="item1" type="text" id="item1"
表單以POST提交的,那么處理表單文件就可以用$_POST['item1']得到變量值,同樣以GET提交的就是$_GET['item1']
是不是很簡單?但是通常$exec會有問題,因為可能您的SQL語句會很長,您會遺漏.連接符,或者'來包圍字符型字段。
我們可以注釋mysql_query($exec);語句用echo $exec;代替來輸出$exec以檢查正確性。如果您還不能察覺$exec有什么錯誤的話,可以復制這個sql語句到phpmyadmin中執(zhí)行,看看它的出錯信息。還有需要注意的是,我們不要使用一些敏感的字符串作為字段名字,否則很可能會出現(xiàn)問題,比如說date什么的。變量的命名,字段的命名遵循一點規(guī)律有的時候對自己是一種好處,初學者并不可忽視其重要性。
學會SESSION的使用
SESSION的作用很多,最多用的就是站點內頁面間變量傳遞。
在頁面開始我們要session_start();開啟SESSION;
然后就可以使用SESSION變量了,比如說要賦值就是:$_SESSION['item']="item1";要得到值就是$item1=$_SESSION['item'];,很簡單吧。這里我們可能會使用到一些函數,比如說判斷是不是某SESSION變量為空,可以這么寫:empty($_SESSION['inum'])返回true or false。
下面綜合一下前面所說的我們來看一個登陸程序,判斷用戶名密碼是否正確。
登陸表單是這樣:login.php
table width="100%" height="100%" border="0" align="center" cellpadding="0" cellspacing="0"
tr
form action="checklogin.php" method="post"td align="center" valign="middle"table width="400" border="0" cellpadding="5" cellspacing="1" class="tablebg"
tr class="tdbg"
td colspan="2"p align="center"Administrators Login/p/td
/tr
tr class="tdbg"
tdp align="center"Username/p/td
tdp align="center"
input name="username" type="text" id="username"
/p/td
/tr
tr class="tdbg"
tdp align="center"Password/p/td
tdp align="center"
input name="password" type="password" id="password"
/p/td
/tr
tr class="tdbg"
td colspan="2"p align="center"
input type="submit" name="Submit" value="Submit"
input type="reset" name="Submit2" value="Clear"
/p/td
/tr
/table/td/form
/tr
/table
處理文件是這樣
?php
require_once('conn.php');
session_start();
$username=$_POST['username'];
$password=$_POST['password'];
$exec="select * from admin where username='".$username."'";
if($result=mysql_query($exec))
{
if($rs=mysql_fetch_object($result))
{
if($rs-password==$password)
{
$_SESSION['adminname']=$username;
header("location:index.php");
}
else
{
echo "scriptalert('Password Check Error!');location.href='login.php';/script";
}
}
else
{
echo "scriptalert('Username Check Error!');location.href='login.php';/script";
}
}
else
{
echo "scriptalert('Database Connection Error!');location.href='login.php';/script";
}
?
conn.php是這樣:
?php
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
?
由于 $_SESSION['adminname']=$username;我們可以這樣寫驗證是否登陸語句的文件:checkadmin.php
?php
session_start();
if($_SESSION['adminname']=='')
{
echo "scriptalert('Please Login First');location.href='login.php';/script";
}
?
做一個分頁顯示
關鍵就是用到了SQL語句中的limit來限定顯示的記錄從幾到幾。我們需要一個記錄當前頁的變量$page,還需要總共的記錄數$num
對于$page如果沒有我們就讓它=0,如果有0就讓它也=0,如果超過了總的頁數就讓他=總的頁數。
$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
這樣可以得到記錄總數
ceil($num/10))如果一頁10記錄的話,這個就是總的頁數
所以可以這么寫
if(empty($_GET['page']))
{
$page=0;
}
else
{
$page=$_GET['page'];
if($page0)$page=0;
if($page=ceil($num/10))$page=ceil($num/10)-1;//因為page是從0開始的,所以要-1
}
這樣$exec可以這么寫 $exec="select * from tablename limit ".($page*10).",10";
//一頁是10記錄的
最后我們需要做的就是幾個連接:
a href="xxx.php?page=0"FirstPage/a
a href="xxx.php?page=?=($page-1)?"PrevPage/a
a href="xxx.php?page=?=($page+1)?"NextPage/a
a href="xxx.php?page=?=ceil($num/10)-1?"LastPage/a
注意事項
1、注意不要漏了分號
2、注意不要漏了變量前的$
3、使用SESSION的時候注意不要遺漏session_start();
如果發(fā)生錯誤的時候,可以采用以下方法:
1、如果是SQL語句出錯,就注釋了然后輸出SQL語句,注意也要注釋調后續(xù)的執(zhí)行SQL語句
2、如果是變量為空,大多是沒有傳遞到位,輸出變量檢查一下,檢查一下表單的id和name
3、如果是數據庫連接出錯,檢查是否正確打開MY SQL和是否遺漏了連接語句
4、注意縮進,排除括號不區(qū)配的錯誤
在做大網站的時候,我的思路是先構建數據庫,確定每一個字段的作用,和表之間的關系。然后設計后臺界面,從添加數據開始做起,因為添加是否成功可以直接到數據庫里面驗證,做好了添加再做顯示的頁面,最后才是兩者的結合。一般來說后臺就包括添加刪除修改和顯示,后臺沒有問題了,前臺也沒有什么大問題。前臺還需要注意安全性和容錯還有就是輸出格式。
學會用PHP上傳文件和發(fā)郵件
上傳文件表單必須加上 enctype="multipart/form-data"
和 input type="file" name="file"
下面看一下代碼:
$f=$HTTP_POST_FILES['file'];
$dest_dir='uploads';//設定上傳目錄
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我這里設置文件名為日期加上文件名避免重復
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//設定上傳的文件的屬性
上傳的文件名為date("ymd")."_".$f['name'] ,可以在以后插入到數據庫的時候用到,PHP實際上是把你上傳的文件從臨時目錄移動到指定目錄。move_uploaded_file($f['tmp_name'],$dest);這是關鍵
至于發(fā)郵件就更加簡單,可以使用mail()函數
mail("收件人地址","主題","正文","From:發(fā)件人\r\nReply-to:發(fā)件人的地址");
不過mail()需要服務器的支持,在WINDOWS下還需要配置SMTP服務器,一般來說外面的LINUX空間都行。
好像上傳文件和發(fā)郵件比ASP簡單很多,只要調用函數就可以了。ASP還需要用到服務器的不同組件比如FSO、JMAIL什么的。
;
PHP是一門高效的網絡編程語言,由于它具有編寫靈活、運行快速等優(yōu)點,迅速成為Web程序員的首選語言。前不久的一份權威調查表明,現(xiàn)在已經有31.6%的網站使用PHP作為主要的服務器端編程語言。
但是,要成為一名PHP編程高手卻并不容易。并不像很多人想象的那樣,只要能夠飛快地編寫幾條簡單的代碼去解決一個復雜的問題就是PHP編程高手了,真正的PHP高手還需要考慮更多的其它問題。以下三條準則是一名成熟的PHP程序員在編程中應該首先遵循的準則。
1.懶惰是金
2.編寫漂亮的代碼
3.追求程序的速度,而不是編程的速度
一、懶惰是金
做一個懶惰的程序員嗎?這個想法太奇怪了!因為這個世界上最忙碌的人可能就是計算機程序員了。但正是因為程序員太忙了,所以才應該在編程時學會偷懶。
對于一個程序員來說,懶惰的方法有兩種:其一,大膽使用現(xiàn)成的別人的程序代碼,把這些代碼融入到你自己的程序或者項目中去。其二是編寫一些有用的代碼建立一個函數庫,在將來編寫程序時可以順手拈來,省去了許多重復的勞動,自然就可以懶惰一點了。
這兩種偷懶的方法都非常適合PHP程序員了。
首先,PHP是在自由開放的環(huán)境中誕生和成長的一門語言。在世界各地,有成千上萬的程序員,他們一直在為PHP的完美而不斷奮斗,他們也愿意和別人分享自己的聰明才智和自己編寫的代碼。你每天都可以從一些PHP網站、郵件列表、新聞組發(fā)現(xiàn)大量的優(yōu)秀的程序代碼。這樣說,我并不是鼓勵你整天等著讓別人為你編寫代碼,但是你可以“站在偉人的肩膀上”,充分發(fā)揚“拿來主義”,聰明地應用別人的程序代碼可以節(jié)省你大量時間。其次,在PHP中,你可以方便地建立自己的函數庫,這樣可以在你以后編寫程序時省去很多麻煩。
下面筆者為大家介紹幾個通用的函數,這些函數有的來自網上的一些開放源代碼的項目,有的精選自郵件列表。如果你能把它們加入到你自己的函數庫中,遲早你將會發(fā)現(xiàn)自己受益無窮。
1.通用數據庫處理函數
和其它的CGI函數相比,PHP的優(yōu)點之一是具有很強大的數據庫處理能力。但是,在PHP中,對于不同的數據庫都使用一些特定的函數來專門處理,缺少通用的數據庫處理函數。這大大降低了程序代碼的可移植性,這也為初學編程的朋友帶來了很多不便。
在網上,許多程序員都通過封裝類解決了這個問題。他們編寫了統(tǒng)一的函數用來處理任何流行的數據庫——不管是在Linux世界深受歡迎的Mysql還是在Windows平臺上廣泛流行的SqlServer。就筆者個人來說,非常喜歡使用這些函數,因為可以直接使用一些簡單的諸如"query"、"next_record"之類的函數,而不需要考慮數據庫的連接、數據庫句柄這些復雜的東西,更不需要考慮使用的是何種數據庫。
如果你需要這些函數,你可以通過訪問以下的幾個網址而得到:
2.變量調試函數
PHP程序的調試一直是一件讓人頭疼的事,它既不像VB等高級語言那樣有集成的編譯調試環(huán)境,也不想Perl那樣可以在Linux或者DOS環(huán)境下直接運行。其實,我們完全可以通過靈活地使用echo語句來完成對PHP的調試工作。
下面的幾個函數可以讓你隨時查看程序中任何變量的類型及其值。
function ss_array_as_string (&$array, $column = 0) {
$str = "Array(
n";
while(list($var, $val) = each($array)){
for ($i = 0; $i $column+1; $i++){
$str .= "    ";
}
$str .= $var. == ;
$str .= ss_as_string($val, $column+1)."
n";
}
for ($i = 0; $i $column; $i++){
$str .= "    ";
}
return $str.);
}
function ss_object_as_string (&$object, $column = 0) {
if (empty($object-classname)) {
return "$object";
}
else {
$str = $object-classname."(
n";
while (list(,$var) = each($object-persistent_slots)) {
for ($i = 0; $i $column; $i++){
$str .= "    ";
}
global $$var;
$str .= $var. == ;
$str .= ss_as_string($$var, column+1)."
n";
}
for ($i = 0; $i $column; $i++){
$str .= "    ";
}
return $str.);
}
}
function ss_as_string (&$thing, $column = 0) {
if (is_object($thing)) {
return ss_object_as_string($thing, $column);
}
elseif (is_array($thing)) {
return ss_array_as_string($thing, $column);
}
elseif (is_double($thing)) {
return "Double(".$thing.")";
}
elseif (is_long($thing)) {
return "Long(".$thing.")";
}
elseif (is_string($thing)) {
return "String(".$thing.")";
}
else {
return "Unknown(".$thing.")";
}
}
需要的時候,在程序中簡單地加入下面的一條代碼即可查看程序中的所使用的變量(包括數組和對象)的類型和值:
echo ss_as_string($my_variable);
使用下面的語句,我們可以直接查看程序中所有的變量的值:
echo ss_as_string($GLOBALS);
3. 控制Log信息的函數
調試PHP程序的另外一種重要的方法就是查看Log信息。如果能夠方便地控制Log信息的級別以及Log信息的顯示內容,將會給程序調試帶來更多的便利。下面的幾個函數可以方便地實現(xiàn)這個功能。
$ss_log_level = 0;
$ss_log_filename = /tmp/ss-log;
$ss_log_levels = array(
NONE = 0,
ERROR = 1,
INFO = 2,
DEBUG = 3);
function ss_log_set_level ($level = ERROR) {
global $ss_log_level;
$ss_log_level = $level;
}
function ss_log ($level, $message) {
global $ss_log_level, $ss-log-filename;
if ($ss_log_levels[$ss_log_level] $ss_log_levels[$level]) {
// 不顯示Log信息
return false;
}
$fd = fopen($ss_log_filename, "a+");
fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");
fclose($fd);
return true;
}
function ss_log_reset () {
global $ss_log_filename;
@unlink($ss_log_filename);
}
在上面的函數中,有四個Log級別變量。運行PHP程序時,只有當Log的級別低于預設的級別值時,Log信息才可以被記錄和顯示出來。例如,在程序中加入如下的一條語句:
ss_log_set_level(INFO);
那么,運行PHP程序時,只有ERROR和INFO級別的LOG信息才能被記錄和顯示出來,DEBUG級的信息則被忽略了。除此之外,我們還可以設定顯示的信息內容,其語句如下:
ss_log(ERROR, "testing level ERROR");
ss_log(INFO, "testing level INFO");
ss_log(DEBUG, "testing level DEBUG");
你也可以隨時使用下面的語句清空LOG信息:
ss_log_reset();
4.速度測試函數
為了優(yōu)化代碼,我們需要一種可以測試代碼運行時間的方法,從而來選擇最優(yōu)的代碼。下面的函數可以測試運行代碼所需的時間:
function ss_timing_start ($name = default) {
global $ss_timing_start_times;
$ss_timing_start_times[$name] = explode( , microtime());
}
function ss_timing_stop ($name = default) {
global $ss_timing_stop_times;
$ss_timing_stop_times[$name] = explode(, microtime());
}
function ss_timing_current ($name = default) {
global $ss_timing_start_times, $ss_timing_stop_times;
if (!isset($ss_timing_start_times[$name])) {
return 0;
}
if (!isset($ss_timing_stop_times[$name])) {
$stop_time = explode(, microtime());
}
else {
$stop_time = $ss_timing_stop_times[$name];
}
$current = $stop_time[1] - $ss_timing_start_times[$name][1];
$current += $stop_time[0] - $ss_timing_start_times[$name][0];
return $current;
}
現(xiàn)在可以輕松地檢查任何一段代碼的執(zhí)行時間了,甚至我們可以同時使用多個計時器,只需在使用上述的幾個函數時設定不同的參數作為計時器的名稱就可以了。
5.調試和優(yōu)化數據庫的操作
對于數據庫來說,運行速度是至關重要的。盡管很多書籍和文章都講授了一些快速運行數據庫的方法,但是所有的方法都必須經過實踐的檢驗。下面我們將把PHPLib函數庫中的query()函數和上面介紹的幾個函數綜合起來編寫成新的query()函數,和原先的函數相比,這個函數增加了運行時間的監(jiān)測功能。
function query($Query_String, $halt_on_error = 1) {
$this-connect();
ss_timing_start();
$this-Query_ID = @mysql_query($Query_String,$this-Link_ID);
ss_timing_stop();
ss_log(INFO, ss_timing_current(). Secs - .$Query_String);
$this-Row = 0;
$this-Errno = mysql_errno();
$this-Error = mysql_error();
if ($halt_on_error && !$this-Query_ID) {
$this-h(huán)alt("Invalid SQL: ".$Query_String);
}
return $this-Query_ID;
}
二、編寫漂亮的代碼
1.將后臺程序與前端程序分開
在編寫PHP程序時,有些代碼是用來處理一些事務,例如操作數據庫、進行數學運算等,而另外的一些代碼則只是事務處理的結果顯示出來,例如一些使用echo語句將結果以HTML的格式顯示在Web瀏覽器上的PHP代碼以及那些直接嵌入PHP程序的HTML代碼。首先我們應該清晰地區(qū)分這兩種代碼,把前者稱為后臺程序,把后者稱為前端程序。
因為PHP是一種嵌入式編程語言,也就是說,所有的PHP代碼都可以嵌入到HTML代碼之中,這為程序的編寫帶來了許多便利之處。但是,“物極必反”,如果在一段較長的程序中將PHP代碼和HTML代碼混合編寫,這將使程序雜亂無章,不利于程序的維護和閱讀。所以我們需要盡可能地將這些程序中混雜于HTML代碼中的PHP代碼移植出來,在專門的文件中將這些代碼封裝成函數,然后在HTML代碼中使用include語句來包含這些文件,在適當的位置調用這些函數即可。
這種做法一方面使HTML代碼和PHP代碼都簡單易讀,另一方面因為HTML代碼需要不斷更新,而這種分離的方法可以確保后臺程序不會被破壞。
同前端程序不同,后臺程序更多追求的是穩(wěn)定、結構化,極少更改,所以應該認真地設計和管理。其實,在設計臺程序時,投入大量時間是值得的,“現(xiàn)在栽樹,以后乘涼”,在以后的設計工作中將可以輕松地使用現(xiàn)在編寫的后臺程序。
2.靈活使用包含文件
正如前面所說的那樣,后臺程序應當安排在一系列的包含文件中。包含文件可以通過include語句在需要時動態(tài)裝入,也可以在php.ini文件中通過使用auto_prepend_file指令預先自動裝入。
如果使用后一種方法的話,雖然取得了一勞永逸的好處,但是也有一些缺點值得我們注意。下面的一段代碼向我們展示了解析一個龐大的包含文件需要一定的時間:
require(timing.inc);
ss_timing_start();
include(test.inc);
ss_timing_stop();
echo
.ss_timing_current().
;
?
在上面的代碼中,test.inc是一個1000行的包含文件,運行的結果顯示,解析這個包含文件花費了0.6秒鐘,對于一個大型網站來說,這個速度并不是可以忽略不記的。
使用包含文件的另外一個缺點是:如果一個文件中的一個語句發(fā)生錯誤,將會使整個網站的PHP程序都無法運行。所以使用起來也及其小心。
其實,對包含文件稍做處理,即可以使包含文件只在需要時進行解析。下面的代碼使abc.inc文件只在程序需要時才作解析:
if ( defined( __LIBA_INC) ) return;
define( __LIBA_INC, 1 );
/*
* 代碼...
*/
?
3.使用面向對象的編程方法
PHP也是一種面向對象的語言,面向對象的編程方法是優(yōu)秀的程序員們非常推崇的一種軟件設計方法,在PHP編程中可以充分發(fā)揮面向對象語言的優(yōu)勢,對編程中的對象進行封裝。在前面的代碼中,我們使用了面向對象的方法,例如在管理數據庫時,我們將query()函數封裝進數據庫類中,這極大地方便了代碼的管理,增加了程序的可讀性。
三、追求程序速度,而不是編程的速度
在網站建設中,程序運行速度和網頁下載速度都是關系成敗的重要因素。作為一名Web程序員,應該更加注意代碼的運行速度。下面介紹的幾種方法都在不同程度上提高了代碼的運行速度。
1.使用內嵌的HTML代碼,而不是PHP的echo語句。
因為PHP是一門嵌入式Web編程語言,可以將HTML代碼和PHP代碼相互嵌入。但是很多程序員擔心在HTML代碼中過多的使用""嵌入PHP代碼會多次調用PHP解釋器,從而降低了PHP代碼的運行速度,所以寧愿使用PHP的echo語句來輸出HTML代碼,而不直接使用HTML代碼。但事實卻恰恰相反。每一個PHP頁面只調用一次PHP解釋器來解釋所有的PHP代碼,所以,只在需要時才嵌入PHP代碼,而大多數的時候直接使用HTML代碼輸入結果,不但不會降低程序的運行速度,而且因為減少了對echo語句的解析,往往可以提高代碼的運行速度。
下面的一段代碼證明了我們的結論。在這段代碼中,我們使用了前面介紹的時間測試函數。
使用str-replace而不是ereg-replace
習慣使用Perl進行編程的程序員更加愿意使用ereg_replace完成字符串替換工作,因為在PHP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的這段代碼證明,使用str_replace 代替 ereg_replace將可以大大提高代碼的運行速度。
測試str_replace和ereg_replace的運行速度
//這段代碼測試str_replace的運行速度
emphasis; ?
for ($i=0; $i1000; $i++) {
str_replace(i, b, $string).
;
}
?
//這段代碼測試ereg_replace的運行速度
for ($i=0; $i1000; $i++) {
ereg_replace(([/]*)i, \1b, $string).
;
}
?
//打印結果
結論
使用str_replace的時間 -
使用ereg_pattern的時間 -
運行上面的代碼,得到的結果是:
使用str_replace的時間 - 0.089757
使用ereg_pattern的時間 - 0.248881
從運行的結果我們可以看出使用str_replace替代ereg_replace作為字符串替換函數,極大地提高了代碼的運行速度。
3.注意字符串的引用
PHP和其它很多編程語言一樣,可以使用雙引號("")來引用字符串,也可以使用單引號()。但是在PHP中,如果使用雙引號來引用字符串,那么PHP解析器將首先分析字符串中有沒有對變量的引用,有變量的話,將對變量進行替換。如果是單引號,則沒有如此復雜——直接將單引號包含起來的所有字符串直接顯示出來。顯然,在PHP編程中,如果使用單引號引用字符串變量要比使用雙引號快速一些。
4.在數據庫中避免使用聯(lián)合操作
比起其它的Web編程語言來說,PHP的數據庫功能十分強大。但是在PHP中數據庫的運行仍然是一件十分費時費力的事情,所以,作為一個Web程序員,要盡量減少數據庫的查詢操作,同時應該為數據庫建立適當的索引。另一件值得注意的事情是在用PHP操作數據庫時,盡可能不使用多個數據表的聯(lián)合操作,盡管聯(lián)合操作可以增強數據庫的查詢功能,但是卻大大增加了服務器的負擔。
為了說明這個問題,我們可以看看下面的這個簡單的例子。
我們在數據庫中創(chuàng)建了兩個數據表foo和big_foo。在數據表foo中,只有一個字段,包含了從1-1000之間的所有自然數。數據表big_foo同樣只有一個字段,但包含了從1-1,000,000之間的全部自然數。所以,從大小上說,big_foo等于foo與它自身進行了聯(lián)合操作。
$db-query("select * from foo");
0.032273 secs
$db-next_record();
0.00048999999999999 secs
$db-query("insert into foo values (NULL)");
0.019506 secs
$db-query("select * from foo as a, foo as b");
17.280596 secs
$db-query("select * from foo as a, foo as b where a.id b.id");
14.645251 secs
$db-query("select * from foo as a, foo as b where a.id = b.id");
0.041269 secs
$db-query("select * from big_foo");
25.393672 secs
從上面操作結果我們可以發(fā)現(xiàn),對于兩個有1000條記錄的數據表進行聯(lián)合,其速度并不比對一個1000000條紀錄的大型數據表單獨進行操作快多少。
5.注意include與require的區(qū)別
在PHP變成中,include()與require()的功能相同,但在用法上卻有一些不同,include()是有條件包含函數,而require()則是無條件包含函數。例如在下面的一個例子中,如果變量$somgthing為真,則將包含文件somefile:
if($something){
include("somefile");
}
但不管$something取何值,下面的代碼將把文件somefile包含進文件里:
if($something){
require("somefile");
}
下面的這個有趣的例子充分說明了這兩個函數之間的不同。
$i = 1;
while ($i 3) {
require("somefile.$i");
$i++;
}
在這段代碼中,每一次循環(huán)的時候,程序都將把同一個文件包含進去。很顯然這不是程序員的初衷,從代碼中我們可以看出這段代碼希望在每次循環(huán)時,將不同的文件包含進來。如果要完成這個功能,必須求助函數include():
$i = 1;
while ($i 3) {
include("somefile.$i");
$i++;
}
6.注意echo和print的區(qū)別
PHP中echo和print的功能也基本相同,但是兩者之間也有細微差別。在PHP代碼中可以把print作為一個普通函數來使用,例如執(zhí)行下面的代碼后變量$res的值將為1。
$ret = print "Hello World";
這意味著print可用在一些復雜的表達式中,而echo則不行。同樣,在代碼中echo語句的運行速度要略微快于print語句,因為echo語句不要求返回任何數值.
網站標題:php數據庫編程教程交流 php做數據庫
路徑分享:http://chinadenli.net/article46/ddgdjhg.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供建站公司、網站導航、做網站、營銷型網站建設、網站收錄、外貿建站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)