PHP mysqli擴(kuò)展是一個(gè)用于通過(guò)PHP腳本與MySQL數(shù)據(jù)庫(kù)進(jìn)行交互的擴(kuò)展庫(kù)。相比于mysql擴(kuò)展,mysqli擴(kuò)展支持更多的功能和特性,同時(shí)也更加安全和穩(wěn)定。在本文中,我們將深入探討mysqli擴(kuò)展的一些基本用法和重要特性。
第一步:連接數(shù)據(jù)庫(kù)
要使用mysqli擴(kuò)展與MySQL數(shù)據(jù)庫(kù)進(jìn)行交互,我們需要首先連接數(shù)據(jù)庫(kù)。以下是一個(gè)連接MySQL數(shù)據(jù)庫(kù)的例子:
$mysqli = new mysqli("localhost", "username", "password", "database"); if ($mysqli->connect_error) { die("連接失敗:" . $mysqli->connect_error); }在上面的代碼中,我們創(chuàng)建了一個(gè)mysqli對(duì)象,并傳遞了連接MySQL數(shù)據(jù)庫(kù)所需的參數(shù)。如果連接失敗,我們會(huì)輸出一個(gè)錯(cuò)誤信息并終止程序執(zhí)行。 第二步:執(zhí)行SQL查詢(xún) 連接成功后,我們可以使用mysqli對(duì)象執(zhí)行各種SQL查詢(xún)語(yǔ)句。以下是一個(gè)簡(jiǎn)單的例子,演示如何執(zhí)行一條SELECT語(yǔ)句:
$sql = "SELECT * FROM users"; $result = $mysqli->query($sql); if ($result->num_rows >0) { while($row = $result->fetch_assoc()) { echo "Name: " . $row["name"]. " - Email: " . $row["email"]. "在上面的代碼中,我們使用mysqli對(duì)象執(zhí)行了一條SELECT語(yǔ)句,并將結(jié)果存儲(chǔ)在$result變量中。如果查詢(xún)結(jié)果集中有一行或多行數(shù)據(jù),我們將使用fetch_assoc()方法逐行取出每一行數(shù)據(jù),并輸出其中的name和email字段值。 第三步:處理SQL語(yǔ)句錯(cuò)誤 在開(kāi)發(fā)過(guò)程中,執(zhí)行SQL語(yǔ)句時(shí)可能會(huì)遇到各種錯(cuò)誤,例如語(yǔ)法錯(cuò)誤、不存在的列、重復(fù)鍵值等。要處理這些錯(cuò)誤,我們可以使用mysqli對(duì)象的error屬性、errno屬性和error_list()方法。 以下是一個(gè)例子,演示如何輸出SQL語(yǔ)句錯(cuò)誤信息:
"; } } else { echo "0 結(jié)果"; }
$sql = "SELECT * FORM users"; // 語(yǔ)法錯(cuò)誤:“FROM”拼寫(xiě)錯(cuò)誤 $result = $mysqli->query($sql); if (!$result) { echo "Error: " . $mysqli->error . "在上面的代碼中,我們故意將FROM拼寫(xiě)錯(cuò)誤,從而產(chǎn)生了一個(gè)語(yǔ)法錯(cuò)誤。執(zhí)行完查詢(xún)后,我們使用error屬性和errno屬性輸出了SQL語(yǔ)句錯(cuò)誤信息和錯(cuò)誤代碼。 第四步:使用預(yù)處理語(yǔ)句 為了防止SQL注入攻擊,我們可以使用mysqli對(duì)象的預(yù)處理語(yǔ)句功能來(lái)執(zhí)行SQL查詢(xún)。預(yù)處理語(yǔ)句是一種能夠設(shè)置查詢(xún)參數(shù)的文本模板,可以在執(zhí)行查詢(xún)之前對(duì)參數(shù)進(jìn)行綁定和過(guò)濾。以下是一個(gè)使用預(yù)處理語(yǔ)句查詢(xún)的例子:
"; echo "Errno: " . $mysqli->errno; }
$stmt = $mysqli->prepare("SELECT name, email FROM users WHERE id=?"); $stmt->bind_param("i", $id); $id = 1; $stmt->execute(); $stmt->bind_result($name, $email); $stmt->store_result(); if ($stmt->num_rows >0) { while ($stmt->fetch()) { echo "Name: " . $name . " - Email: " . $email . "在上面的代碼中,我們首先使用prepare()方法創(chuàng)建了一個(gè)預(yù)處理語(yǔ)句模板。然后,使用bind_param()方法綁定了一個(gè)整數(shù)參數(shù)$id到預(yù)處理語(yǔ)句中的問(wèn)號(hào)占位符。接著,執(zhí)行prepare語(yǔ)句并使用bind_result()將結(jié)果的每一列與變量$name和$email綁定。最后,使用fetch()方法取出每一行的數(shù)據(jù)結(jié)果,并將其輸出到屏幕。 總結(jié) PHP mysqli擴(kuò)展是一個(gè)強(qiáng)大且安全的庫(kù),用于與MySQL數(shù)據(jù)庫(kù)進(jìn)行交互。在本文中,我們學(xué)習(xí)了連接到MySQL數(shù)據(jù)庫(kù)、執(zhí)行SQL查詢(xún)語(yǔ)句、處理SQL語(yǔ)句錯(cuò)誤和使用預(yù)處理語(yǔ)句等基本用法。當(dāng)然,mysqli庫(kù)還有很多特性和功能,如事務(wù)處理、存儲(chǔ)過(guò)程等,我們只是挖掘了其中的一部分。如果你想深入了解mysqli庫(kù)或在項(xiàng)目中使用mysqli庫(kù),我們還需更加細(xì)致深入地學(xué)習(xí)和練習(xí)。
"; } } else { echo "0 結(jié)果"; } $stmt->close();
下一篇css圓角代碼加邊框