ホームページ >データベース >mysql チュートリアル >PHP および MySQL でキーワードベースの複数テーブル検索を実行するにはどうすればよいですか?

PHP および MySQL でキーワードベースの複数テーブル検索を実行するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-14 19:07:02836ブラウズ

How to Perform a Keyword-Based Multi-Table Search in PHP and MySQL?

PHP MySQL: キーワードを使用した複数テーブルの検索

キーワードを使用して MySQL データベース内の複数のテーブルから結果を検索するのは困難な場合があります。この記事では、「messages.content」、「messages.title」、「topics.content」、「topics.title」、「comments.content」、および「comments.title」の 3 つの別々の検索の問題に対処します。 「LIKE」演算子を使用したテーブル (「メッセージ」、「トピック」、および「コメント」)。

複数テーブル検索のクエリ:

複数のテーブルにわたる検索では、UNION 演算子を利用できます。次のクエリは、各テーブルの結果を結合します:

$query = "(SELECT content, title, 'msg' as type FROM messages WHERE content LIKE '%" .
           $keyword . "%' OR title LIKE '%" . $keyword ."%')
           UNION
           (SELECT content, title, 'topic' as type FROM topics WHERE content LIKE '%" .
           $keyword . "%' OR title LIKE '%" . $keyword ."%')
           UNION
           (SELECT content, title, 'comment' as type FROM comments WHERE content LIKE '%" .
           $keyword . "%' OR title LIKE '%" . $keyword ."%')";

mysql_query($query);

結果のテーブルの起源の特定:

結果が取得されたら、各行の元となるテーブル。このため、テーブル名を示す「type」列を各行に追加しました (「msg」は「messages」、「topic」は「topics」、「comment」は「comments」) を示します。クエリの実行後、結果にアクセスし、「type」列に基づいて並べ替えることで、特定のテーブルから行を分離できます。

使用例:

としましょう。キーワード「example」があり、一致する結果をすべて検索したいと考えています。複数テーブル検索では、3 つのテーブルのいずれかの「コンテンツ」フィールドまたは「タイトル」フィールドにキーワードが出現するすべての行が返されます。その後、「type」列を使用して結果をグループ化し、テーブルごとに個別に表示できます。

以上がPHP および MySQL でキーワードベースの複数テーブル検索を実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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