Dalam ORM Eloquent Laravel, anda mungkin menghadapi senario di mana anda perlu mendapatkan semula baris terkini untuk setiap nilai yang berbeza dalam lajur tertentu. Ini boleh dicapai menggunakan gabungan subkueri dan fungsi pengagregatan.
Pertimbangkan senario di mana anda mempunyai jadual pangkalan data yang mengandungi lajur berikut:
id seller_id amount created_at
Andaikan anda ingin mendapatkan yang paling terkini rekod untuk setiap seller_id unik. Begini cara anda boleh mencapainya menggunakan pertanyaan SQL mentah:
<code class="sql">select s.* from snapshot s left join snapshot s1 on s.seller_id = s1.seller_id and s.created_at < s1.created_at where s1.seller_id is null
Dalam pertanyaan ini, kami menggunakan gabungan kiri untuk membandingkan setiap rekod dalam jadual syot kilat (disebut sebagai s) dengan semua rekod lain yang mempunyai rekod yang sama id_penjual. Kami kemudian menggunakan syarat AND untuk menapis rekod yang s.created_at adalah kurang daripada s1.created_at. Akhir sekali, kami menyertakan klausa WHERE untuk mengecualikan sebarang rekod dengan seller_id yang sepadan dalam jadual kanan (s1), dengan berkesan mengasingkan rekod terkini untuk setiap seller_id.
Untuk mencapai hasil yang sama menggunakan pembina pertanyaan Laravel, anda boleh melaksanakan kod berikut:
<code class="php">DB::table('snapshot as s') ->select('s.*') ->leftJoin('snapshot as s1', function ($join) { $join->on('s.seller_id', '=', 's1.seller_id') ->whereRaw(DB::raw('s.created_at < s1.created_at')); }) ->whereNull('s1.seller_id') ->get();</code>
Pendekatan pembina pertanyaan ini mencerminkan logik pertanyaan SQL mentah, merangkumnya dalam antara muka lancar Laravel. Ia mengembalikan koleksi rekod terkini untuk setiap seller_id berbeza yang terdapat dalam jadual syot kilat.
Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Rekod Terkini untuk Setiap Nilai Unik dalam Lajur menggunakan Laravel Eloquent?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!