Jadual Kandungan
Cara Mendapatkan Semua Baris dengan Max Created_at dalam Laravel Eloquent
Rumah pembangunan bahagian belakang tutorial php 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?

Oct 26, 2024 pm 12:55 PM

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
Salin selepas log masuk

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 &lt; s1.created_at
where s1.seller_id is null
Salin selepas log masuk

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')
  -&gt;select('s.*')
  -&gt;leftJoin('snapshot as s1', function ($join) {
        $join-&gt;on('s.seller_id', '=', 's1.seller_id')
             -&gt;whereRaw(DB::raw('s.created_at &lt; s1.created_at'));
   })
  -&gt;whereNull('s1.seller_id')
  -&gt;get();</code>
Salin selepas log masuk

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 Laman Web ini
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

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

11 skrip pemendek URL terbaik PHP (percuma dan premium) 11 skrip pemendek URL terbaik PHP (percuma dan premium) Mar 03, 2025 am 10:49 AM

11 skrip pemendek URL terbaik PHP (percuma dan premium)

Pengenalan kepada API Instagram Pengenalan kepada API Instagram Mar 02, 2025 am 09:32 AM

Pengenalan kepada API Instagram

Bekerja dengan Data Sesi Flash di Laravel Bekerja dengan Data Sesi Flash di Laravel Mar 12, 2025 pm 05:08 PM

Bekerja dengan Data Sesi Flash di Laravel

Respons HTTP yang dipermudahkan dalam ujian Laravel Respons HTTP yang dipermudahkan dalam ujian Laravel Mar 12, 2025 pm 05:09 PM

Respons HTTP yang dipermudahkan dalam ujian Laravel

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Mar 14, 2025 am 11:42 AM

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

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React Mar 04, 2025 am 09:33 AM

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

12 skrip sembang php terbaik di codecanyon 12 skrip sembang php terbaik di codecanyon Mar 13, 2025 pm 12:08 PM

12 skrip sembang php terbaik di codecanyon

Pemberitahuan di Laravel Pemberitahuan di Laravel Mar 04, 2025 am 09:22 AM

Pemberitahuan di Laravel

See all articles