在PHP網(wǎng)站開(kāi)發(fā)過(guò)程中,查詢(xún)是非常常見(jiàn)的操作,特別是與數(shù)據(jù)庫(kù)相關(guān)的查詢(xún)。mysqli是一個(gè)PHP擴(kuò)展庫(kù),它提供了與mysql數(shù)據(jù)庫(kù)交互的功能。本文將介紹mysqli查詢(xún)的相關(guān)知識(shí)。
在使用mysqli進(jìn)行查詢(xún)前,需要先連接數(shù)據(jù)庫(kù)。以下是一個(gè)連接MySQL數(shù)據(jù)庫(kù)的示例代碼:
$mysqli = new mysqli("localhost","username","password","database"); if($mysqli->connect_error){ die("連接失敗: ".$mysqli->connect_error); }
以上代碼中,"localhost"代表連接本地?cái)?shù)據(jù)庫(kù),“username”和“password”分別代表數(shù)據(jù)庫(kù)的用戶(hù)名和密碼,“database”代表連接的數(shù)據(jù)庫(kù)名稱(chēng)。
mysqli的查詢(xún)語(yǔ)句與常規(guī)的SQL查詢(xún)語(yǔ)句相似。以下是一個(gè)簡(jiǎn)單的查詢(xún)示例:
$sql = "SELECT * FROM users WHERE age< 30"; $result = $mysqli->query($sql);
以上代碼中,SQL語(yǔ)句“SELECT * FROM users WHERE age< 30”將會(huì)查詢(xún)數(shù)據(jù)庫(kù)中“users”表中年齡小于30的所有記錄。$mysqli->query($sql)可以將這個(gè)SQL語(yǔ)句發(fā)送到數(shù)據(jù)庫(kù)執(zhí)行,并返回查詢(xún)結(jié)果。
為了讓返回結(jié)果更有意義,可以使用PHP的fetch函數(shù)來(lái)逐行讀取結(jié)果。以下是一個(gè)示例代碼:
while($row = $result->fetch_assoc()){ echo "姓名:" . $row["name"] . " 年齡:" . $row["age"] . "
"; }
以上代碼中,$result->fetch_assoc()函數(shù)可以逐行讀取返回結(jié)果。每一行數(shù)據(jù)將會(huì)形成一個(gè)關(guān)聯(lián)數(shù)組$row,其元素由字段名和字段值組成。在本例中,“name”和“age”都是數(shù)據(jù)表users中的字段名。
在實(shí)際開(kāi)發(fā)中,查詢(xún)語(yǔ)句可能需要帶有多個(gè)參數(shù)或條件。以下是一個(gè)使用mysqli進(jìn)行參數(shù)查詢(xún)的示例:
$name = "John"; $age = 25; $sql = "SELECT * FROM users WHERE name=? AND age=?"; $stmt = $mysqli->prepare($sql); $stmt->bind_param("si", $name, $age); $stmt->execute(); $result = $stmt->get_result();
以上代碼中,$sql中的“?”表示查詢(xún)參數(shù)的占位符。$stmt使用了預(yù)處理語(yǔ)句,這樣可以在SQL查詢(xún)中加入?yún)?shù),防止SQL注入攻擊。$stmt->bind_param("si", $name, $age)將$name和$age綁定到SQL查詢(xún)語(yǔ)句中的參數(shù)上,其第一個(gè)參數(shù)“si”表示“s”代表字符串,i代表整數(shù)。$stmt->execute()將查詢(xún)語(yǔ)句發(fā)送到數(shù)據(jù)庫(kù)并返回查詢(xún)結(jié)果。
mysqli查詢(xún)結(jié)果也可以存儲(chǔ)到數(shù)組中。以下是一個(gè)使用mysqli查詢(xún)結(jié)果存放到數(shù)組中的示例:
$data = array(); while($row = $result->fetch_assoc()){ array_push($data, $row); } print_r($data);
以上代碼中,$data數(shù)組用于存放查詢(xún)結(jié)果。$result->fetch_assoc()函數(shù)可以逐行讀取返回結(jié)果,并且每一行數(shù)據(jù)以關(guān)聯(lián)數(shù)組的形式存儲(chǔ)。array_push($data, $row)可以將每一行的數(shù)據(jù)加入到$data數(shù)組中。最后使用print_r函數(shù)打印出查詢(xún)數(shù)據(jù),以便于調(diào)試。
綜上所述,mysqli是一個(gè)強(qiáng)大的PHP擴(kuò)展庫(kù),使用簡(jiǎn)單而靈活。通過(guò)mysqli可以輕松地進(jìn)行SQL查詢(xún),并能夠提高代碼的安全性。需要注意的是,查詢(xún)語(yǔ)句中的所有變量都需要進(jìn)行正確的轉(zhuǎn)義和過(guò)濾,以避免SQL注入攻擊。同時(shí),還需要注意使用預(yù)處理語(yǔ)句和綁定參數(shù),是代碼更加安全可靠。