首頁 >資料庫 >mysql教程 >為什麼 PHP 拋出「致命錯誤:未捕獲錯誤:呼叫未定義的函數 mysql_connect()」以及如何修復它?

為什麼 PHP 拋出「致命錯誤:未捕獲錯誤:呼叫未定義的函數 mysql_connect()」以及如何修復它?

Barbara Streisand
Barbara Streisand原創
2024-12-11 07:06:12360瀏覽

Why is PHP Throwing a

為什麼 PHP 顯示「致命錯誤:未捕獲錯誤:呼叫未定義的函數 mysql_connect()」?

當嘗試與使用XAMPP的MySQL資料庫,有可能遇到錯誤「Fatal error: Uncaught Error: Call to undefined function mysql_connect()。」此錯誤表示PHP 無法辨識mysql_connect() 函數,導致連線失敗。

理解問題

mysql_* 函數,包括 mysql_connect( ),在 PHP 5.5 中已棄用,並在 PHP 7 中刪除。此更改是出於對安全性和性能的考慮。如果您仍在使用 PHP 7 或更高版本,您將無法再使用 mysql_connect()。

解決方案

要解決此錯誤,您有兩種選擇:

  • MySQLi: MySQL 改進版(MySQLi)擴充提供了一組更新的函數,用於連接到MySQL 資料庫並與之互動。
  • PDO(PHP 資料物件): PDO 是一個資料庫抽象層,可讓您使用以下方式與不同的資料庫進行互動通用 API,包括 MySQL。

範例使用MySQLi:

$mysqli = new mysqli($mysql_hostname, $mysql_username, $mysql_password);
if ($mysqli->connect_error) {
    echo "Connection failed: " . $mysqli->connect_error;
}

使用 PDO的範例:

$pdo = new PDO("mysql:host=$mysql_hostname;dbname=$mysql_database", $mysql_username, $mysql_password);

結論

記得使用 MySQLi或 PDO 在 PHP 7 或更高版本中使用 MySQL 資料庫時。透過採用這些現代替代方案,您不僅可以解決「致命錯誤:未捕獲錯誤:呼叫未定義函數 mysql_connect()」問題,還可以提高資料庫互動的安全性和效能。

以上是為什麼 PHP 拋出「致命錯誤:未捕獲錯誤:呼叫未定義的函數 mysql_connect()」以及如何修復它?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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