ホームページ > データベース > mysql チュートリアル > グループごとの最大値を効率的に見つけるためにクエリを最適化するにはどうすればよいですか?

グループごとの最大値を効率的に見つけるためにクエリを最適化するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-26 10:51:10
オリジナル
630 人が閲覧しました

How Can I Optimize a Query to Efficiently Find the Groupwise Maximum?

効率的なグループごとの最大値を実現するために最適化されたクエリ

元の問題:

クエリ

select * 
from records 
where id in ( select max(id) from records group by option_id )
ログイン後にコピー

レコード テーブル全体の順次スキャンを実行して、各レコードの最大 ID を決定します。オプションID。このアプローチは、特に大きなテーブルの場合、非効率的です。

解決策: 水平結合

1 つの解決策は、水平結合を利用して、サブクエリ内の各 option_id の最大 ID をフェッチすることです:

select r.*
from records r
cross join lateral (
    select max(id) as max_id
    from records
    where option_id = r.option_id
) m
where r.id = m.max_id
ログイン後にコピー

このクエリは、横結合を使用して、別のサブクエリで最大 ID を計算します。結果は元のレコード テーブルと結合され、最大 ID を持つ行のみがフィルターされます。

特殊なインデックスの作成

もう 1 つの最適化は、レコード テーブルに特殊なインデックスを作成して、各 option_id の最大 ID:

CREATE INDEX idx_max_id ON records (option_id, max(id))
ログイン後にコピー

このインデックスにより、指定された option_id の最大 ID の直接検索が可能になり、必要がなくなります。元のサブクエリの場合:

select * 
from records r
where (option_id, id) in (
    select option_id, max(id) from records group by option_id
)
ログイン後にコピー

インデックス ベースのアプローチにより、テーブル アクセスの数が大幅に削減され、大規模なテーブルのクエリがより効率的になります。

以上がグループごとの最大値を効率的に見つけるためにクエリを最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート