


Bagaimana untuk Mendapatkan Rekod Terkini untuk Setiap Nilai Unik dalam Lajur menggunakan Laravel Eloquent?
Oct 26, 2024 pm 12:55 PMCara 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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

11 skrip pemendek URL terbaik PHP (percuma dan premium)

Bekerja dengan Data Sesi Flash di Laravel

Respons HTTP yang dipermudahkan dalam ujian Laravel

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React

12 skrip sembang php terbaik di codecanyon
