ホームページ >データベース >mysql チュートリアル >PHP および 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 サイトの他の関連記事を参照してください。