MySQL で上位 N の最大値を取得する方法
MySQL テーブルをクエリして、最大値を含む上位行を取得する場合特定の列では、重複値がどのように処理されるかを考慮することが重要です。この記事では、この操作の微妙な違いを詳しく掘り下げ、正確な解決策を提供します。
正確な上位 N 行の取得
上位 N 行のみを取得するには、次のクエリを実行します。利用可能:
select * from t order by value desc limit N
上位 N 行と任意の行の取得Ties
先頭の行が同じ値を持つ場合、上記のクエリを使用すると、結合された行が省略されます。これらを含めるには、追加の手順が必要です。
select * from t join (select min(value) as cutoff from (select value from t order by value limit N ) tlim ) tlim on t.value >= tlim.cutoff;
このクエリは、サブクエリを使用して、上位 N 値の最小値であるカットオフ値を決定します。カットオフ以上の値を持つ行が結果に含まれます。
概念的だがサポートされていない可能性があるクエリ
理論的には、次のクエリも次のクエリを達成する必要があります。望ましい結果ですが、サポートされていない可能性がありますMySQL:
select * from t where t.value >= ANY (select value from t order by value limit N)
結論
この記事で説明されている方法は、MySQL で上位 N 個の最大値を取得するときに重複値を処理する効果的な方法を提供します。選択するアプローチは、クエリの特定の要件 (同順位を含めるか、上位 N 行に厳密に従うか) に基づいて決定する必要があります。
以上がMySQL で上位 N 個の最大値を取得するときに重複値を処理する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。