データベース パターン: プログレッシブ検索の UNION ALL
データベース内のデータを検索する場合、場合によっては、結果が見つかりました。これは一般に「プログレッシブ検索」として知られています。
次のシナリオを考えてみましょう。名前とグループ ID に基づいて、イメージ テーブル内の単一行を検索したいとします。それでも結果が得られない場合は、グループ ID なしで同じ名前を検索し、それでも結果が得られない場合は、名前なしでグループ ID を検索します。
プログレッシブ検索クエリ
プログレッシブ検索のための最も効率的な SQL クエリ
SELECT * FROM image WHERE name = 'text' AND group_id = 10 UNION ALL SELECT * FROM image WHERE name = 'text' UNION ALL SELECT * FROM image WHERE group_id = 10 LIMIT 1;
説明
最適化
最適なパフォーマンスを確保するには、イメージ テーブルに次のインデックスを作成することが重要です:
CREATE INDEX image_name_grp_idx ON image (name, group_id); CREATE INDEX image_grp_idx ON image (group_id);
スケーラビリティ
このプログレッシブ検索クエリはスケーラブルであり、さまざまな精度で複数のパラメータを検索するように適合させることができます。各パラメータに SELECT ステートメントを追加し、それに応じて基準を調整するだけです。
結論
ここで紹介する UNION ALL クエリは、プログレッシブ検索のための多用途のソリューションです。これにより、速度と精度の両方を確保しながら、データを段階的に検索できます。これらのガイドラインに従うことで、データベース アプリケーションにプログレッシブ検索を効果的に実装できます。
以上がUNION ALL はプログレッシブ データベース検索をどのように実装できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。