ホームページ > データベース > mysql チュートリアル > SQL で特定のフィールドの最小値を持つ個別の行を選択する方法は?

SQL で特定のフィールドの最小値を持つ個別の行を選択する方法は?

Barbara Streisand
リリース: 2025-01-17 20:15:10
オリジナル
577 人が閲覧しました

How to Select Distinct Rows with the Minimum Value for a Specific Field in SQL?

最も古いレコード日を持つ一意の行の選択

一意の識別子ごとに複数のエントリを含むテーブルがあり、各識別子の最も古い記録日を表す一意の行のみを取得する必要があるとします。 これは、重複した記録日を扱う場合に特に便利です。

この問題を効率的に解決する SQL クエリを次に示します。

<code class="language-sql">SELECT mt.*
FROM MyTable mt
INNER JOIN (
    SELECT id, MIN(record_date) AS MinDate
    FROM MyTable
    GROUP BY id
) t ON mt.id = t.id AND mt.record_date = t.MinDate;</code>
ログイン後にコピー

このクエリは 2 つのステップで機能します:

  1. 最小日付の検索: 内部クエリ (SELECT id, MIN(record_date) AS MinDate FROM MyTable GROUP BY id) は、一意の各 record_date の最小 id を識別します。

  2. 一致する行の選択: 外部クエリは、内部クエリの結果を元のテーブル (MyTable) と結合します。 MyTableid の両方が内部クエリで見つかった最小の日付と一致する行のみを record_date から選択します。

最終結果には、一意の識別子ごとに最も古い record_date を持つ行のみが含まれ、記録日が異なる重複行は排除されます。

以上がSQL で特定のフィールドの最小値を持つ個別の行を選択する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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