ホームページ > データベース > mysql チュートリアル > 重複した日付を持つテーブル内の各個別 ID の最も古いレコードを効率的に見つけるにはどうすればよいですか?

重複した日付を持つテーブル内の各個別 ID の最も古いレコードを効率的に見つけるにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-17 19:56:14
オリジナル
433 人が閲覧しました

How to Efficiently Find the Earliest Record for Each Distinct ID in a Table with Duplicate Dates?

各一意の ID の最初のレコードを抽出し、重複する日付を処理する

MyTablekey_idid、およびその他の列 (record_date) を含むテーブル (other_cols と呼びます) を想像してください。 目標は、すべての一意の record_date について、最も古い id を含む行を特定することです。

標準メソッドでは、多くの場合、一意の record_date 値が想定されますが、データには重複がある可能性があります。 サブクエリと結合を使用した複雑なクエリは、不要な結果を招く可能性があります。

より合理化されたアプローチでは、サブクエリを使用します。

<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>
ログイン後にコピー

内部サブクエリは、データをグループ化することで、各 record_date の最も古い MinDate (id) を効率的に見つけます。次に、外側のクエリはこの結果を元のテーブル (MyTable) に結合し、record_date がサブクエリで見つかった最小の日付と一致する行のみを選択します。 これにより、一意の各 id の最も古いレコードが効果的に取得され、重複する日付が適切に処理され、冗長データが回避されます。

以上が重複した日付を持つテーブル内の各個別 ID の最も古いレコードを効率的に見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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