Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mendapatkan Rekod Terkini untuk Setiap Nilai Unik dalam Lajur menggunakan Laravel Eloquent?

Bagaimana untuk Mendapatkan Rekod Terkini untuk Setiap Nilai Unik dalam Lajur menggunakan Laravel Eloquent?

Susan Sarandon
Susan Sarandonasal
2024-10-26 12:55:02702semak imbas

How to Retrieve the Latest Records for Each Unique Value in a Column using Laravel Eloquent?

Cara Mendapatkan Semua Baris dengan Max Created_at dalam Laravel Eloquent

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!

Kenyataan:
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