ホームページ  >  記事  >  バックエンド開発  >  MySQL-PHP コードを最新化する方法: 非推奨の `mysql_*` 関数をプリペアド ステートメントと PDO に置き換える?

MySQL-PHP コードを最新化する方法: 非推奨の `mysql_*` 関数をプリペアド ステートメントと PDO に置き換える?

Susan Sarandon
Susan Sarandonオリジナル
2024-10-26 18:25:03616ブラウズ

How to Modernize Your MySQL-PHP Code: Replacing Deprecated `mysql_*` Functions with Prepared Statements and PDO?

非推奨の mysql_* 関数による古い MySQL-PHP コードの書き換え

PHP が進化するにつれて、mysql_* コマンドを含む特定の関数が非推奨になります。セキュリティと安定性を強化するには、これらのコマンドをプリペアド ステートメントと PDO に置き換える必要があります。

キーの置換:

  • mysql_connect を PDO::__construct() に置き換えます。 .
  • mysql_select_db を PDO 接続文字列内のデータベース名の設定に置き換えます (例: mysql:host=127.0.0.1;dbname=people)。

コード サンプル:

<code class="php"> // Old deprecated code
$db = new dbConn('127.0.0.1', 'root', 'pass', 'people', 'animals');

 // New PDO code
$db = new PDO('mysql:host=127.0.0.1;dbname=people;charset=UTF-8', 'root', 'pass');</code>

追加の考慮事項:

  • コンストラクターとデストラクター: __construct() 関数と __destruct() 関数は、接続と終了を内部で処理するため、PDO では必要です。
  • データベース選択: データベース選択が PDO 接続文字列に埋め込まれるようになりました。接続文字列で dbname パラメータを使用して、目的のデータベースを指定します。

クラス例:

次のクラス例は、selectDb メソッドを次を使用して書き換える方法を示しています。 PDO:

<code class="php">class DB
{
    private $pdo;

    public function __construct($host, $db, $user, $pass)
    {
        // Establish PDO connection
        $this->pdo = new PDO("mysql:host=$host;dbname=$db;charset=UTF-8", $user, $pass);
    }

    public function selectDatabase($dbName)
    {
        // No longer required with PDO
    }
}</code>

結論:

非推奨の mysql_* 関数をプリペアド ステートメントと PDO に置き換えることで、開発者はデータベースを簡素化しながらコードのセキュリティと安定性を強化できます。インタラクション。

以上がMySQL-PHP コードを最新化する方法: 非推奨の `mysql_*` 関数をプリペアド ステートメントと PDO に置き換える?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。