ホームページ >バックエンド開発 >PHPチュートリアル >PHP で PDO プリペアドステートメントを使用して LIKE クエリを実行するにはどうすればよいですか?

PHP で PDO プリペアドステートメントを使用して LIKE クエリを実行するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-01 17:03:301020ブラウズ

How to Execute a LIKE Query with PDO Prepared Statements in PHP?

MySQL LIKE クエリを使用した PHP PDO プリペアド ステートメント

この記事では、PHP の PDO クラス (MySQL ドライバー) を使用して LIKE を実行する問題に取り組みます。 MySQL データベースを使用してクエリを実行します。

PDO のexecute() メソッドで使用される構文が MySQL クライアントと異なるため、プリペアド ステートメントで LIKE を利用しようとすると問題が発生します。

構文が正しくありません:

<code class="php">$ret = $prep->execute(array(':searchTerm' => '"%'.$searchTerm.'%"'));</code>

は不必要な二重引用符を追加し、不正確な結果をもたらします。

同様に、次の構文も正しくありません:

<code class="php">$ret = $prep->execute(array(':searchTerm' => '%'.$searchTerm.'%'));</code>

には、必要な追加の構文が欠けています。

PDO プリペアド ステートメントを使用して LIKE クエリを実行するための正しい構文は次のとおりです。

<code class="php">$prep = $dbh->prepare($sql);
$ret = $prep->execute(array(':searchTerm' => '%'.$searchTerm.'%'));</code>

プリペアド ステートメントは SQL インジェクションから保護するため、文字列連結よりも利点があります。値をクエリとは別個のエンティティとして扱い、面倒な連結の必要性を排除します。

以上がPHP で PDO プリペアドステートメントを使用して LIKE クエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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