Bagaimana untuk mendapatkan semula baris dalam lajur dengan nilai tertinggi menggunakan SQL [pendua]
P粉211273535
P粉211273535 2023-09-20 13:44:50
0
2
707

Saya mempunyai jadual dokumen (di sini adalah versi ringkas):

id Ubah hala Kandungan
1 1 ...
2 1 ...
1 2 ...
1 3 ...

Bagaimana untuk memilih satu baris untuk setiap id dan hanya memilih rev terbesar?

Berdasarkan data di atas, hasilnya harus mengandungi dua baris: [1, 3, ...][2, 1, ..]. Saya menggunakan MySQL.

Pada masa ini, saya menggunakan semak dalam whilegelung untuk mengesan dan menulis ganti rev lama dalam set hasil. Tetapi adakah ini satu-satunya cara untuk mencapai hasil? Adakah tiada penyelesaian SQL?

P粉211273535
P粉211273535

membalas semua(2)
P粉714780768

Saya lebih suka menggunakan kod sesedikit mungkin...

Anda boleh menggunakan IN untuk mencapai Cuba ini:

SELECT * 
FROM t1 WHERE (id,rev) IN 
( SELECT id, MAX(rev)
  FROM t1
  GROUP BY id
)

Pada pendapat saya, ini lebih mudah... lebih mudah dibaca dan diselenggara.

P粉336536706

Sepintas lalu...

Anda hanya perlukan GROUP BY子句中使用MAXfungsi pengagregatan:

SELECT id, MAX(rev)
FROM YourTable
GROUP BY id

Perkara tidak pernah semudah itu, bukan?

Saya baru perasan bahawa anda juga memerlukan content lajur.

Dalam SQL, ini adalah masalah yang sangat biasa: cari seluruh baris data dengan nilai maksimum dalam lajur tertentu berdasarkan pengecam kumpulan tertentu. Saya telah banyak mendengar soalan ini dalam kerjaya saya. Sebenarnya, ini adalah soalan yang saya jawab semasa temuduga teknikal untuk pekerjaan saya sekarang.

Soalan ini sebenarnya sangat biasa sehingga komuniti Stack Overflow mencipta teg khusus untuk menangani soalan jenis ini: .

Pada asasnya, anda mempunyai dua cara untuk menyelesaikan masalah ini:

Sertai menggunakan group-identifier, max-value-in-groupsubquery

mudah

Dalam pendekatan ini anda mula-mula menemui group-identifier, max-value-in-group(已经在上面解决了)。然后,你将你的表与子查询进行连接,使用group-identifiermax-value-in-group dalam subkueri (sudah diselesaikan di atas). Anda kemudian sertai jadual anda dengan subkueri, menggunakan

dan max-value-in-group untuk equijoin:

SELECT a.id, a.rev, a.contents
FROM YourTable a
INNER JOIN (
    SELECT id, MAX(rev) rev
    FROM YourTable
    GROUP BY id
) b ON a.id = b.id AND a.rev = b.rev

Gunakan sambung sendiri untuk sambung kiri dan laraskan syarat sambung dan syarat penapis

group-identifierDalam pendekatan ini, anda melakukan cantuman kiri jadual dengan dirinya sendiri. Equijoins diletakkan di

. Kemudian, ada dua langkah bijak:
  1. Syarat sambungan kedua ialah nilai di sebelah kiri kurang daripada nilai di sebelah kanan
  2. NULL(记住这是一个LEFT JOIN)。然后,我们过滤连接的结果,只显示右侧为NULLApabila anda melakukan langkah 1, baris yang sebenarnya mempunyai nilai terbesar ialah baris dengan
  3. di sebelah kanan.

Jadi, anda akan mendapat:

SELECT a.*
FROM YourTable a
LEFT OUTER JOIN YourTable b
    ON a.id = b.id AND a.rev < b.rev
WHERE b.id IS NULL;

Kesimpulan

Kedua-dua kaedah akan memberikan anda hasil yang sama.

group-identifier中有两行具有max-value-in-groupJika terdapat dua baris dengan nilai-maks-dalam-kumpulan dalam

, maka kedua-dua baris ini akan muncul dalam hasil dalam kedua-dua kaedah.

Kedua-dua kaedah ini serasi dengan SQL ANSI, jadi tidak kira apa "rasa" RDBMS yang anda suka, anda boleh menggunakannya.

Kedua-dua kaedah juga mesra prestasi, tetapi situasi sebenar anda mungkin berbeza (RDBMS, struktur pangkalan data, indeks, dll.). Jadi apabila memilih kaedah, lakukan penanda aras

. Pastikan anda memilih kaedah yang paling sesuai untuk anda. 🎜
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan