溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP Web查詢數(shù)據(jù)庫基本步驟是什么

發(fā)布時間:2021-10-18 16:43:23 來源:億速云 閱讀:158 作者:柒染 欄目:編程語言

這篇文章給大家介紹PHP Web查詢數(shù)據(jù)庫基本步驟是什么,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

PHP是開發(fā)WEB動態(tài)頁面的***編程,最近看了一本書收獲很多,現(xiàn)在和大家一起分享一下PHP Web查詢數(shù)據(jù)庫的知識,下面我們就一起來看看吧。從PHP Web查詢數(shù)據(jù)庫的基本步驟:

1. 檢查并過濾來自用戶的數(shù)據(jù) 首先,我們將過濾用戶可能在其搜索條件的起始或結(jié)束位置不小心輸入的空白字符,這是用函數(shù)trim()來實現(xiàn)。 我們這么麻煩的檢查用戶輸入數(shù)據(jù)的原因是防止多個接口連接數(shù)據(jù)庫,因為用戶從不同的界面進入,這樣可能導致安全問題。

然后,當準備使用用戶輸入的任何數(shù)據(jù)時,也要適當?shù)倪^濾一些控制字符,當用戶輸入數(shù)據(jù)到數(shù)據(jù)庫時必須轉(zhuǎn)義數(shù)據(jù),,此時使用盜的函數(shù)有 addslashes()函數(shù)、stripslashes()函數(shù)和get_magic_qutoes_gpc()函數(shù)。 addslashes()函數(shù)為了數(shù)據(jù)庫查詢語句等的需要在某些字符前加上了反斜線;stripslashes()函數(shù)去掉字符串中的反斜線字符;get_magic_qutoes_gpc()函數(shù) 魔術(shù)添加轉(zhuǎn)義字符 “”,獲取當前活動配置magic_quotes_runtime設置,如果運行時關(guān)閉魔術(shù)引號,返回0,否則返回1。我們也可以使用 htmispecialchars()對HTML中的特殊意義字符警醒編碼,htmispecialchars()函數(shù)把一些預定義的字符轉(zhuǎn)換為 HTML 實體 預定義的字符是:& (和號) 成為 & " (雙引號) 成為 " ' (單引號) 成為 ' < (小于) 成為 < > (大于) 成為 >

2. 建立一個到適當數(shù)據(jù)庫的連接 PHP為連接MySQL提供了函數(shù)庫mysqli(i表示改進)。

當在PHP中使用mysqli函數(shù)庫是可以使用面向?qū)ο蠡蛎嫦蜻^程的語法:

1)面向?qū)ο螅?@ $db = new mysqli('hostname','username','password','dbname');返回一個對象

2)面向過程: @ $db = mysqli_connect('hostname','username','password','dbname');返回一個資源,這個資源表示數(shù)據(jù)庫的連接,而且 如果使用過程方法,必須將這個資源傳遞到mysqli的所有其它函數(shù)。

這與處理函數(shù)非常類似mysqli的大多數(shù)函數(shù)都有面向?qū)ο蠼涌诤瓦^程接口,二者的差異則在于過程版本的函數(shù)名稱以mysqli_開頭,同時要求傳入 mysqli_connect()函數(shù)獲得的資源句柄。對于這個規(guī)則來說,數(shù)據(jù)可連接是一個異常,因為它是由mysqli對象的構(gòu)造函數(shù)來創(chuàng)建的。因此嘗試連接時需要進行檢查,mysqli_connect_errno()函數(shù)將在出現(xiàn)連接 錯誤時返回一個錯誤號,如果成功,則返回0.

請注意:當連接到數(shù)據(jù)庫是,通常會議錯誤抑制符@作為***含代碼。這樣可以巧妙的處理任何錯誤,也可以通過異常來處理。另外,MySQK對同時連接數(shù)據(jù)庫的連接數(shù)量有一定的限制。MySQLi參數(shù)max_connections決定了同時連接的個數(shù),該參數(shù)和相關(guān)的Apache參數(shù) MaxClients的作用是告訴服務器拒絕新的連接請求,從而保證系統(tǒng)資源不會再系統(tǒng)忙碌時或系統(tǒng)癱瘓時被請求或使用。要設置Apache中的 MaxClients參數(shù)可以編輯系統(tǒng)中的httpd.conf文件。要為MySQLi設置max_connections參數(shù)可以編輯文件my.conf。

選擇使用的數(shù)據(jù)庫: 在MySQL命令行使用 use dbname;命令;在php中可以用$db->select_db(dbname);或mysqli_select_db(db_resource,dbname)。

3. 查詢數(shù)據(jù)庫 要執(zhí)行數(shù)據(jù)庫查詢,首先應構(gòu)造查詢語句:$query = "select  from user";然后運行 $result = $db->query($query);或者$result = mysqli_query($db,$query); 面向?qū)ο蟀姹緦⒎祷匾粋€結(jié)果對象;過程版本將返回一個結(jié)果資源。無論何種方法都將結(jié)果保存在$result變量中工以后使用。如果函數(shù)運行失敗將返回 false。

4. 獲取查詢結(jié)果 使用不同的函數(shù)以不同的方式將查詢結(jié)果從結(jié)果對象或標識符中取出來,結(jié)果對象或標識符是訪問查詢返回行的關(guān)鍵。

通常我們要得到結(jié)果集中記錄行的行數(shù),并且使用mysqli_fetch_assoc()函數(shù)。返回行數(shù):$num_results = $result->num_rows;(行數(shù)保存在對象的num_rows成員變量中)或$num_results = mysqli_num_rows($result);然后使用循環(huán)遍歷每一行,在循環(huán)中調(diào)用 $row = $result->fectch_assoc();或者 $row = mysqli_fetch_assoc($result);返回該行的信息。如果是對象返回行則每個關(guān)鍵詞為一個屬性名,每個值為屬性中的相應的值;如果以資源返回則返回數(shù)組。

還有其他從結(jié)果標識符中獲取結(jié)果的方法,例如:使用$row = $result->fecth_row($result);或者$row = mysqli_fetch_row($result);將結(jié)果取回到一個列舉數(shù)組中;也可以使用$row = $result->fecth_object();或者 $row = mysqli_fecth_object($result);江一行去回到一個對象中。

5. 從數(shù)據(jù)庫斷開 先釋放結(jié)果集:$result->free();或 mysqli_free_result($result);然后關(guān)閉數(shù)據(jù)庫連接:$db->close()或者 mysqli_close($db); 嚴格的說,這并不必須,因為腳本執(zhí)行完畢的時候他們將被自動關(guān)閉。

關(guān)于PHP Web查詢數(shù)據(jù)庫基本步驟是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI