


Bagaimana untuk Mendapatkan Rekod Terkini untuk Setiap Nilai Unik dalam Lajur menggunakan 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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat 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

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

Respons HTTP yang dipermudahkan dalam ujian Laravel

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

12 skrip sembang php terbaik di codecanyon

Pengumuman Penyiasatan Situasi PHP 2025
