PHP mysqli 是數據庫連接擴展,提供了訪問 MySQL 服務器的能力。與舊版的 MySQL 擴展相比,mysqli 擴展具有更多的功能和更好的性能。下面我們就來詳細了解一下 mysqli 的使用。
在使用 mysqli 擴展之前,我們需要創建一個數據庫連接。可以使用以下語法來建立一個數據庫連接:
$conn = mysqli_connect($servername, $username, $password, $dbname);其中,$servername 是 MySQL 服務器地址,$username 是數據庫用戶名,$password 是數據庫密碼,$dbname 是要連接的數據庫名稱。 如果連接成功,$conn 變量將包含一個連接對象。 下面是一個完整的示例:
//數據庫連接信息 $servername = "localhost"; $username = "root"; $password = ""; $dbname = "test_db"; // 創建連接 $conn = mysqli_connect($servername, $username, $password, $dbname); // 檢查連接 if (!$conn) { die("連接失敗:" . mysqli_connect_error()); } echo "連接成功";在上面的代碼中,我們首先定義了連接信息,然后使用 mysqli_connect() 函數創建一個連接。如果連接失敗,我們使用 die() 函數輸出“連接失敗”并退出腳本,否則輸出“連接成功”。 連接成功后,我們可以執行 SQL 語句來與數據庫交互。在 mysqli 中,可以使用 mysqli_query() 函數執行查詢。 例如,如果我們想選擇一個名為 "user" 的表,可以使用以下代碼:
// 選擇表 $sql = "SELECT * FROM user"; $result = mysqli_query($conn, $sql);在上面的代碼中,我們定義了一個 SQL 語句,然后使用 mysqli_query() 函數執行查詢。如果查詢成功,$result 變量將包含一個結果集。 可以使用 mysqli_fetch_assoc() 函數獲取結果集中的數據行。 例如,以下代碼可以將所有數據行遍歷并輸出:
// 輸出數據 if (mysqli_num_rows($result) >0) { while($row = mysqli_fetch_assoc($result)) { echo "id: " . $row["id"]. " - Name: " . $row["name"]. " - Age: " . $row["age"]. "在上面的代碼中,我們首先使用 mysqli_num_rows() 函數檢查結果集是否包含數據行。如果包含,使用 while 循環遍歷每個數據行,并使用 echo 輸出行的 id、name 和 age 字段。 在使用 mysqli 擴展時,需要注意以下幾點: 1.使用 mysqli 函數時需要確保已安裝并啟用了相應的 PHP 模塊。 2.在向 SQL 查詢傳遞變量時,需要使用 mysqli_real_escape_string() 函數防止 SQL 注入攻擊。 3.在執行查詢后,需要使用 mysqli_free_result() 函數釋放結果集。 4.最后,需要使用 mysqli_close() 函數關閉數據庫連接。 下面是一個完整的示例:
"; } } else { echo "0 結果"; }
//數據庫連接信息 $servername = "localhost"; $username = "root"; $password = ""; $dbname = "test_db"; // 創建連接 $conn = mysqli_connect($servername, $username, $password, $dbname); // 檢查連接 if (!$conn) { die("連接失敗:" . mysqli_connect_error()); } //查詢 $name = mysqli_real_escape_string($conn, $_POST['name']); $sql = "SELECT * FROM user WHERE name = '$name'"; $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) >0) { while($row = mysqli_fetch_assoc($result)) { echo "id: " . $row["id"]. " - Name: " . $row["name"]. " - Age: " . $row["age"]. "以上就是 mysqli 擴展的使用方法和注意事項,希望對大家有幫助。
"; } } else { echo "0 結果"; } //釋放結果集和關閉連接 mysqli_free_result($result); mysqli_close($conn);