從 PHP 5.6 升級到 7.0 時,從 MySQL 過渡到 MySQLi 至關重要。這種轉變可能會帶來挑戰,特別是在嘗試從不同的類別存取 MySQLi 連線時。這個問題強調了這樣一種情況,即嘗試使用資料庫類別從 API 類別連接到資料庫會導致內部伺服器錯誤。
問題的根源在於遵守良好的程式設計實踐。從資料庫類別擴展使用者是不正確的,資料庫類別本身缺乏重要的功能。要解決此錯誤並改善整體設計,請考慮以下步驟:
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中文網其他相關文章!