Mencari Nilai Paling Biasa untuk Setiap Nilai dalam Lajur Lain dalam SQL
Apabila bekerja dengan data jadual, selalunya perlu mengenal pasti nilai yang paling kerap berlaku untuk lajur tertentu. Dalam konteks SQL, ini boleh dicapai menggunakan pelbagai kaedah.
Pendekatan Konvensional:
Satu pendekatan biasa ialah menggunakan satu siri langkah perantaraan, sebagai ditunjukkan dalam soalan. Ini melibatkan mencipta jadual sementara untuk mengira kejadian, mengenal pasti nilai maksimum dan mengumpulkan hasil dengan sewajarnya. Walaupun kaedah ini berfungsi, ia boleh menyusahkan dan terdedah kepada ralat.
Penyelesaian Elegan:
Versi SQL moden, seperti PostgreSQL 9.4 dan lebih baru, tawaran dipermudahkan penyelesaian untuk tugasan ini. Fungsi mod() mengembalikan nilai yang paling biasa dalam kumpulan tertentu. Ini menghapuskan keperluan untuk pengagregatan dan manipulasi yang kompleks.
Contoh:
Pertimbangkan jadual berikut:
Column | Type | Modifiers |
---|---|---|
country | text | |
food_id | int | |
eaten | date |
Untuk mencari makanan yang paling kerap dimakan untuk setiap negara, kita boleh menggunakan pertanyaan berikut:
select mode() within group (order by food_id) from munch group by country
Pertanyaan ini secara langsung mengembalikan mod untuk setiap negara, memberikan pendekatan yang lebih mudah dan cekap.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencari Nilai Paling Kerap dengan Cekap dalam Satu Lajur untuk Setiap Nilai Unik dalam Lajur Lain Menggunakan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!