首頁 >後端開發 >php教程 >為什麼應該從 MySQL 函數遷移到 PDO?

為什麼應該從 MySQL 函數遷移到 PDO?

Patricia Arquette
Patricia Arquette原創
2024-11-11 05:29:03352瀏覽

Why Should I Migrate from MySQL Functions to PDO?

如何從MySQL 函數移轉到PDO

簡介

為什麼不建議使用 MySQL 函數

MySQL 函數過時且容易出現安全問題漏洞,使它們不適合現代 PHP 應用程式。它們缺乏便利的功能並且難以安全地應用。 PDO 和 MySQLI 解決了這些問題並提供了重大改進。

使用 PDO 連接到 MySQL

PHP 模組
    php_pdo_mysql.dll
  1. 是必要。
  2. 使用下列指令建立PDO 實例
  3. DSN(資料來源名稱)

    :

    $dsn = 'mysql:dbname=databasename;host=127.00 .0.1';
    • $dbh = 新PDO ($dsn,$用戶, $password);
使用PDO 連接到MSSQL

安裝
    php_pdo_sqlsrv_##_ts.dll
  1. php_pdo_sqlsrv_##_nts.dll 驅動程式。
  2. 使用
  3. DSN(資料來源名稱)

    建立PDO 實例:

    $dsn = 'sqlsrv:Server=127.0.0.1;名';
    • $dbh = new PDO($dsn, $user, $password);
使用Prepared執行查詢語句

PDO 使用準備好的語句,透過清理插入SQLSQL查詢的使用者輸入來防止SQL 注入。要準備語句:

    使用
  1. ->prepare()

    建立準備好的語句。

    $SQL = 'SELECT ID,來自使用者的電子郵件,其中user = :username';
    • $stmt = $dbh->prepare($SQL);
  2. 使用
  3. ->bindValue()

    將參數綁定到準備好的語句:

    $stmt->bindValue(':使用者名稱', $username);
執行查詢

    使用
  1. -> 執行準備好的語句執行()

    不傳遞任何參數:

    $stmt->execute();
  2. 直接查詢,使用
  3. ->query()

    :

    $結果= $dbh->query($SQL);
取得結果

fetch()

取得結果集中的一行。 fetchAll() 將所有行提取到陣列中。

PDO 範例類別

結論

從程式碼移轉到PDOMy顯著改進資料庫安全性並為您的應用程式未來的PHP 版本做好準備。提供的程式碼範例和範例類別應該有助於順利過渡。

以上是為什麼應該從 MySQL 函數遷移到 PDO?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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