ホームページ >データベース >mysql チュートリアル >PDO プリペアド ステートメントが MySQL へのデータの挿入に失敗するのはなぜですか?
PHP PDO: プリペアドステートメントを使用した安全かつ効率的な MySQL 挿入
プリペアド ステートメントは、PDO (PHP データ オブジェクト) を使用した PHP での安全かつ効率的なデータベース操作に不可欠です。 ただし、よくある落とし穴により、挿入エラーが発生する可能性があります。典型的な問題とその解決策を見てみましょう。
問題: 間違ったアプローチ
準備されたステートメントを介して MySQL の挿入を試みる、一見正しいコード スニペットについて考えてみましょう。
<code class="language-php">$statement = $link->prepare("INSERT INTO testtable(name, lastname, age) VALUES('Bob','Desaunois','18')"); $statement->execute();</code>
このコードは、構文的には有効ですが、多くの場合失敗します。 データベースは変更されません。
解決策: 適切なパラメータのバインディング
正しいアプローチでは、名前付きまたは名前なしのプレースホルダーを利用してパラメータを安全にバインドします。
名前付きプレースホルダーの使用:
<code class="language-php">$statement = $link->prepare('INSERT INTO testtable (name, lastname, age) VALUES (:fname, :sname, :age)'); $statement->execute([ 'fname' => 'Bob', 'sname' => 'Desaunois', 'age' => '18', ]);</code>
このバージョンでは、名前付きプレースホルダー (:fname
、:sname
、:age
) と連想配列を使用して値をバインドします。 これは、明確さと読みやすさを考慮して推奨されるアプローチです。
名前のないプレースホルダーの使用:
または、名前のないプレースホルダー (?
) を使用することもできます:
<code class="language-php">$statement = $link->prepare('INSERT INTO testtable (name, lastname, age) VALUES (?, ?, ?)'); $statement->execute(['Bob', 'Desaunois', '18']);</code>
ここで、配列内の値の順序は、SQL ステートメント内のプレースホルダーの順序と厳密に一致する必要があります。
これが機能する理由: SQL インジェクションを防止し、パフォーマンスを向上させる
準備されたステートメントには次のような大きな利点があります。
パラメータ バインディングを備えたプリペアド ステートメントを正しく利用することで、PHP アプリケーションで安全かつ最適化されたデータベース インタラクションを確保できます。
以上がPDO プリペアド ステートメントが MySQL へのデータの挿入に失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。