SELECTクエリの応用_PHPチュートリアル
Jul 13, 2016 pm 05:01 PM
たとえば、多くの記事のタイトルから「MySQL」という単語を含むすべての記事を検索したいとします。これは、あいまいクエリである WHERE 句で「LIKE」を使用する必要があることを意味します。
まず、SQL 言語のワイルドカードについて説明します。SQL では、文字「_」は任意の 1 文字と一致し、文字「%」は任意の文字と一致します。 。たとえば、「A_」は「AA」、「AB」、「A2」、「A$」などに一致し、「A%」は「ABCD」、「A」、「AG$Bng0 ",」に一致します。リンゴはただのリンゴだ」…などなど。
使い方は?実際の例を見てみましょう。工場の倉庫には多くのものがあり、非常に複雑です。たとえば、カテゴリ A は機械付属品、カテゴリ B は工具、カテゴリ C は梱包材を表します。 ...など、カテゴリの下にあるものには、「A0001」、「A1065」、「B1014」などのように個別に番号が付けられます。このデータベースを管理する際、この番号はアイテムのコード名としてだけでなく、そのカテゴリを示すフィールドとしても使用されます。すべてのツールをクエリしたい場合は、次のようにすることができます:
SELECT * FROM Goods WHERE code LIKE 'B%' ORDER BY code'
これは、コード フィールド (つまり、番号) が文字で始まるすべてのレコードをクエリします。 B.ここでの「B%」は、文字 B がフィールドの先頭に表示されることを意味し、次の例とは異なります。記事タイトルに単語「MySQL」を含むすべての記事を検索します。これは、ターゲット「MySQL」が検索されたキーワードは、必ずしも記事タイトルのどの位置に表示されるわけではないため、次のようにする必要があります:
SELECT * FROMarticle WHERE title LIKE '%MySQL%'
'%MySQL%' は、単語「MySQL」がタイトルに表示されることを意味します。前にテキストがある場合もあれば、後ろにテキストがある場合もあります。
「MySQL」で検索できるので、他の単語で検索することも不可能ではありません。次のように、視聴者に検索したいキーワードを入力させることができます:
<!--input.php:-->
<form method="get" action="search.php">
キーワード: <input type="text" size=10 name="key"> <input type="submit" value="query">
<! .php :-->
<?
...
$query="タイトルが '%$key%' から * を選択します。"; .. .
?>
ファジークエリを使用する場合、注意が必要な状況があります。つまり、フィールドに '2,13,25,33' のような値がある場合、 '2' が含まれています。1 つの項目に対して、単純に '%2%' を使用してクエリを実行することはできません。その場合、「1,6,21,27」のような値も照会されるためです。これは私たちが望んでいることではありません。したがって、このような問題に対処する場合、このフィールドは「.2.13.25.33」の形式で保存する必要があります。このようにして、項目 '2' を含むレコードをクエリする必要がある場合、安全に '%.2.%' を使用できます。
急いでいたので急いで書きました、不正確な点があれば修正してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP で MySQL クエリのパフォーマンスを最適化するにはどうすればよいですか?

PHP で MySQL のバックアップと復元を使用するにはどうすればよいですか?

データベースにおける Java 列挙型のアプリケーション シナリオは何ですか?

PHP を使用して MySQL テーブルにデータを挿入するにはどうすればよいですか?

MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法

PHP で MySQL ストアド プロシージャを使用するにはどうすればよいですか?

PHP を使用して MySQL テーブルを作成するにはどうすればよいですか?
