在PHP 中從外部類別使用MySQL
從PHP 5.6 遷移到7.0,並進行對應的資料庫調整,從sqlSql 到sqlSql 到sqlSql已經揭示了某些挑戰。在這裡,我們將深入研究根本問題並提供替代解決方案。
理解結構
首先,您設計了一個具有私有屬性和建構子的資料庫類別建立連線。但是,此設定會在從其他類別存取時造成斷開連線。
其次,您有一個旨在與資料庫互動的 API 類,但它在其建構函式中使用單獨的新實例化來進行資料庫連接。
錯誤根源:內部不一致
當您從 API 類別引用 $this->db->conn 時,它會檢索 null,從而導致內部伺服器錯誤。發生這種情況是因為 $this->db 僅在物件建立時初始化,並且它不保留任何連接資料。
建議的解決方案:依賴注入
相反每個類別的單獨實例化,請考慮依賴注入。操作方法如下:
透過遵循這些原則,您可以在 PHP 應用程式中跨多個類別有效地利用 MySQLi。
範例實作
資料庫.php:
<code class="php">$db = new mysqli("localhost", "DBUserName", "UserPassword", "SelectedDB"); $db->set_charset('utf8mb4');</code>
myapi.php:
<code class="php">class MyAPI { protected $db; public function __construct($db) { $this->db = $db; } // ... Rest of your code }</code>
app.php:
<code class="php">require 'database.php'; require 'myapi.php'; $api = new MyAPI($db); // Utilize the API as intended</code>這種重組可確保整個應用程式對資料庫資源的存取一致,從而減少您遇到的內部伺服器錯誤。
以上是如何在 PHP 中從外部類別存取 MySQLi:透過依賴注入克服內部伺服器錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!