Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Cekap Mencari Rekod Terawal untuk Setiap ID Berbeza dalam Jadual dengan Pendua Tarikh?

Bagaimana untuk Cekap Mencari Rekod Terawal untuk Setiap ID Berbeza dalam Jadual dengan Pendua Tarikh?

Linda Hamilton
Lepaskan: 2025-01-17 19:56:14
asal
433 orang telah melayarinya

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

Mengekstrak Rekod Pertama untuk Setiap ID Unik, Mengendalikan Tarikh Pendua

Bayangkan jadual (mari kita panggilnya MyTable) dengan lajur: key_id, id, record_date dan lajur lain (other_cols). Matlamatnya adalah untuk menentukan baris yang mengandungi record_date terawal untuk setiap id unik.

Kaedah standard selalunya menganggap nilai record_date unik, tetapi data kami mungkin mempunyai pendua. Pertanyaan rumit menggunakan subqueries dan join boleh membawa kepada hasil yang tidak perlu.

Pendekatan yang lebih diperkemas menggunakan subkueri:

<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>
Salin selepas log masuk

Subkueri dalaman cekap mencari record_date (MinDate) yang paling awal untuk setiap id dengan mengumpulkan data. Pertanyaan luar kemudiannya menggabungkan hasil ini kembali ke jadual asal (MyTable), hanya memilih baris yang record_date sepadan dengan tarikh minimum yang terdapat dalam subkueri. Ini dengan berkesan mendapatkan semula rekod paling awal untuk setiap id unik, mengendalikan tarikh pendua dengan anggun dan mengelakkan data berlebihan.

Atas ialah kandungan terperinci Bagaimana untuk Cekap Mencari Rekod Terawal untuk Setiap ID Berbeza dalam Jadual dengan Pendua Tarikh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan