Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mendapatkan Kembali 5 Lagu Teratas Paling Didengar Menggunakan ActiveRecord dalam Ruby on Rails dengan Cekap?
Dengan Cekap Mendapatkan Lagu Teratas Didengar Menggunakan ActiveRecord
Dalam Ruby on Rails, mendapatkan semula rekod paling popular berdasarkan kiraan model yang berkaitan ialah tugas biasa. Dalam kes ini, kami mempunyai model Lagu dan model Listen di mana setiap Listen adalah milik Lagu, dan setiap Lagu boleh mempunyai berbilang Dengar. Untuk menentukan lima lagu teratas yang paling banyak didengari, kami perlu mengakses maklumat persatuan dengan cara yang cekap.
Menggunakan Skop Dinamakan
skop bernama ActiveRecord menyediakan skop yang berkuasa cara untuk merangkum pertanyaan kompleks. Ia membolehkan kami mencipta kriteria pertanyaan boleh guna semula yang boleh digunakan dengan mudah. Untuk senario yang diberikan, kita boleh mentakrifkan skop bernama :top5 dalam model Lagu:
class Song has_many :listens scope :top5, select("songs.id, OTHER_ATTRS_YOU_NEED, count(listens.id) AS listens_count"). joins(:listens). group("songs.id"). order("listens_count DESC"). limit(5) # Retrieve the top 5 most listened-to songs songs = Song.top5
Pecahan Pertanyaan
Dengan menggunakan skop yang dinamakan :top5, kita boleh mendapatkan koleksi lima lagu teratas dengan kiraan mendengar yang berkaitan, menyediakan cara yang ringkas dan cekap untuk mengekstrak data yang diperlukan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan Kembali 5 Lagu Teratas Paling Didengar Menggunakan ActiveRecord dalam Ruby on Rails dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!