首頁 >後端開發 >PHP問題 >php封裝一個資料庫查詢的函數

php封裝一個資料庫查詢的函數

PHPz
PHPz原創
2023-03-23 17:21:021552瀏覽

在網站開發中,對於資料庫的操作是非常常見的。而對於PHP語言,查詢資料庫也是一個非常重要的功能。在PHP中,我們透過MySQLi和PDO兩種擴充去操作資料庫。

而在使用MySQLi和PDO查詢資料庫時,我們通常需要寫很長的程式碼,這增加了不必要的程式碼量和開發時間。針對這種情況,我們可以封裝從資料庫查詢的函數,以達到程式碼最佳化和提高開發效率的目的。

一、MySQLi查詢封裝函數

使用MySQLi查詢時,我們可以封裝下列查詢函數:

  1. 連接資料庫函數:
function connectDb() {
    $servername = "yourservername";
    $username = "yourusername";
    $password = "yourpassword";
    $dbname = "yourdbname";

    // 创建连接
    $conn = new mysqli($servername, $username, $password, $dbname);

    // 检测连接
    if ($conn->connect_error) {
        die("连接失败: " . $conn->connect_error);
    }
    return $conn;
}
  1. 查詢函數:
function selectDb($query) {
    $conn = connectDb();

    $result = $conn->query($query);
    if ($result === false) {
        die("查询失败: " . $conn->error);
    }

    $data = array();
    while ($row = $result->fetch_assoc()) {
        $data[] = $row;
    }

    $conn->close();

    return $data;
}
  1. #插入、更新、刪除函數:
function updateDb($query) {
    $conn = connectDb();

    if ($conn->query($query) === true) {
        $status = true;
    } else {
        $status = false;
    }

    $conn->close();

    return $status;
}

二、 PDO查詢封裝函數

使用PDO查詢時,我們可以封裝以下查詢函數:

  1. 連接資料庫函數:
function connectDb() {
    $host = "yourhost";
    $username = "yourusername";
    $password = "yourpassword";
    $dbname = "yourdbname";

    try {
        $conn = new PDO("mysql:host=$host;dbname=$dbname;charset=utf8", $username, $password);
        // 设置 PDO 错误模式为异常
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    } catch(PDOException $e) {
        echo "连接失败: " . $e->getMessage();
    }
    
    return $conn;
}
  1. #查詢函數:
function selectDb($query) {
    $conn = connectDb();

    $stmt = $conn->prepare($query);
    $stmt->execute();

    $data = array();
    while ($row = $stmt->fetch()) {
        $data[] = $row;
    }

    $conn = null;

    return $data;
}
  1. 插入、更新、刪除函數:
function updateDb($query) {
    $conn = connectDb();

    $status = true;

    try {
        $conn->beginTransaction();

        $stmt = $conn->prepare($query);
        $stmt->execute();

        $conn->commit();
    } catch(PDOException $e) {
        $conn->rollBack();
        $status = false;
    }

    $conn = null;

    return $status;
}

透過對上述兩種查詢封裝函數的使用,我們可以大幅減少查詢資料庫所需的程式碼行數,提升程式碼效率和開發效率。

總結

開發中,封裝函數是提高程式碼品質和開發效率不可或缺的一部分。而在進行資料庫查詢操作時,我們可以透過資料庫查詢封裝函數,優化查詢程式碼,提升開發效率。以上封裝函數僅供參考,讀者可根據具體項目需求進行更改和完善。

以上是php封裝一個資料庫查詢的函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn