首頁 >資料庫 >mysql教程 >如何從不同的 PHP 類別正確存取 MySQLi 資料庫連線?

如何從不同的 PHP 類別正確存取 MySQLi 資料庫連線?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-18 02:29:09493瀏覽

How Can I Properly Access a MySQLi Database Connection from Different PHP Classes?

從 PHP 中的其他類別存取 MySQLi 連線

從 PHP 5.6 升級到 7.0 時,從 MySQL 過渡到 MySQLi 至關重要。這種轉變可能會帶來挑戰,特別是在嘗試從不同的類別存取 MySQLi 連線時。這個問題強調了這樣一種情況,即嘗試使用資料庫類別從 API 類別連接到資料庫會導致內部伺服器錯誤。

問題的根源在於遵守良好的程式設計實踐。從資料庫類別擴展使用者是不正確的,資料庫類別本身缺乏重要的功能。要解決此錯誤並改善整體設計,請考慮以下步驟:

  1. 消除冗餘的資料庫類別。它沒有特定目的,並引入了不必要的複雜性。
  2. 從普通 MySQLi 建立單一 $db 實例。此實例將作為所有資料庫操作的中央連接點。
  3. 將 $db 執行個體作為建構子參數傳遞給每個需要資料庫連線的類別。透過執行這些步驟,您可以建立一個更乾淨且更容易維護的程式碼庫。更新後的程式碼結構可能類似:
database.php
<?php
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$db = new mysqli("localhost", "DBUserName", "UserPassword", "SelectedDB");
$db->set_charset('utf8mb4');
myapi.php
<?php
class MyAPI
{
    protected $db;

    public function __construct($db, $request_uri, $postData, $origin)
    {
        $this->db = $db;
    }

    public function getUser($id)
    {
        $sql = "SELECT * FROM users where>
app.php
<?php
require 'vendor/autoload.php'; // autoloading is recommended

$api = new MyAPI($db, $request_uri, $postData, $origin);
$user = $api->getUser($_POST['id']);

以上是如何從不同的 PHP 類別正確存取 MySQLi 資料庫連線?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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