Bagaimana untuk Memesan mengikut Tarikh Sebelum Mengumpulkan dalam MySQL?

Linda Hamilton
Lepaskan: 2024-11-15 02:27:02
asal
474 orang telah melayarinya

How to Order by Date Before Grouping in MySQL?

Pesanan MySQL sebelum Kumpulan Oleh

Masalahnya:

Untuk mencari jawatan terkini untuk setiap pengarang dan kumpulan hasilnya, kami perlu memesan siaran mengikut tarikh sebelum menggunakan kumpulan mengikut operasi. Walau bagaimanapun, pertanyaan yang diberikan adalah menyusun keputusan selepas mengumpulkan, yang boleh membawa kepada hasil yang salah.

Penyelesaian:

Untuk menyelesaikan isu ini, kita boleh menggunakan HAVING klausa bukannya ORDER BY dalam kumpulan mengikut operasi. Klausa HAVING membenarkan kami menggunakan syarat pada data agregat dan mengecualikan kumpulan yang tidak memenuhi syarat.

SELECT wp_posts.*
FROM wp_posts
WHERE wp_posts.post_status = 'publish'
AND wp_posts.post_type = 'post'
GROUP BY wp_posts.post_author
HAVING wp_posts.post_date = MAX(wp_posts.post_date)
ORDER BY wp_posts.post_date DESC;
Salin selepas log masuk

Dengan meletakkan syarat dalam klausa HAVING, kami memastikan bahawa keputusan ditapis sebelum kumpulan secara operasi digunakan. Ini menjamin bahawa setiap pengarang hanya mempunyai catatan terkini mereka yang disertakan dalam keputusan.

Pertimbangan Tambahan:

Kaedah pesanan sebelum pengumpulan ini khusus untuk MySQL dan mungkin tidak berfungsi dalam pangkalan data lain seperti Postgres atau SQL Server. Untuk pangkalan data ini, pendekatan alternatif, seperti menggunakan subkueri atau bergabung dengan jadual nilai maksimum, mungkin diperlukan.

Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa menggunakan GROUP BY dengan pesanan boleh menjadi cekap untuk set data yang besar dalam MySQL, terutamanya jika data tidak diagihkan secara sama rata merentas kumpulan. Oleh itu, adalah disyorkan untuk menggunakan kaedah ini apabila sesuai untuk mengoptimumkan prestasi.

Atas ialah kandungan terperinci Bagaimana untuk Memesan mengikut Tarikh Sebelum Mengumpulkan dalam MySQL?. 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