Dalam Laravel, kita selalunya perlu menanyakan beberapa rekod pertama daripada pangkalan data, seperti menanyakan lima produk jualan teratas dalam kategori produk. Dalam kes ini, kami biasanya menggunakan pertanyaan kumpulan untuk mencapai ini.
Artikel ini akan memperkenalkan cara melaksanakan pertanyaan kumpulan dalam Laravel dan menanyakan beberapa rekod pertama setiap kumpulan.
Pertama, kita perlu mempunyai jadual data untuk menyimpan maklumat produk. Katakan kita telah mencipta jadual data yang dipanggil "produk" dan memasukkan beberapa data ke dalamnya.
Kita boleh menggunakan pembina pertanyaan Laravel untuk menulis pernyataan pertanyaan. Pertama, kita perlu mengumpulkan produk mengikut kategori, dan kemudian menanyakan lima produk teratas dalam setiap kumpulan. Pernyataan pertanyaan adalah seperti berikut:
$products = DB::table('products') ->select('category', DB::raw('MAX(sales) as max_sales')) ->groupBy('category') ->orderByDesc('max_sales') ->limit(5) ->get();
Di sini kami menggunakan kaedah pilih() untuk menentukan medan yang hendak ditanya, dan kaedah DB::raw() untuk mengira volum jualan maksimum setiap kumpulan. Kaedah groupBy() menentukan pengelompokan mengikut medan kategori, kaedah orderByDesc() mengisih mengikut jualan maksimum dalam tertib menurun, dan kaedah had() mengehadkan bilangan rekod yang ditanya kepada 5. Akhir sekali, gunakan kaedah get() untuk melaksanakan pertanyaan dan mengembalikan set hasil dengan kategori sebagai kunci dan volum jualan maksimum sebagai nilai.
Seterusnya, kita perlu memproses hasil pertanyaan untuk mendapatkan lima produk teratas setiap kumpulan. Kita boleh memproses set hasil dalam gelung, menanyakan lima item pertama dalam setiap kumpulan, dan menambahnya pada tatasusunan baharu.
$result = []; foreach ($products as $product) { $query = DB::table('products') ->select('*') ->where('category', $product->category) ->orderByDesc('sales') ->limit(5) ->get(); $result[$product->category] = $query; }
Di dalam gelung, kami mula-mula menanyakan semua produk di bawah setiap kategori, kemudian mengisih mengikut volum jualan dalam tertib menurun, mengehadkan bilangan rekod pertanyaan kepada 5 dan akhirnya menambah hasil pertanyaan pada tatasusunan baharu. Selepas gelung berakhir, kami mendapat tatasusunan baharu dengan kategori sebagai kunci dan hasil pertanyaan sebagai nilai Tatasusunan ini mengandungi lima produk jualan teratas dalam setiap kategori.
Akhir sekali, kita boleh melintasi tatasusunan baharu dan mengeluarkan hasil pertanyaan ke halaman.
foreach ($result as $category => $products) { echo '<h3>'.$category.'</h3>'; echo '<ul>'; foreach ($products as $product) { echo '<li>' . $product->name . '</li>'; } echo '</ul>'; }
Apabila mengeluarkan keputusan, kami mula-mula mengeluarkan nama kategori, dan kemudian mengeluarkan nama setiap produk dalam senarai ul.
Dalam artikel ini, kami memperkenalkan cara menggunakan pertanyaan berkumpulan dalam Laravel untuk menanyakan beberapa rekod pertama setiap kumpulan. Dengan menggunakan select(), groupBy(), orderByDesc(), limit() dan kaedah lain, kami boleh menulis pernyataan pertanyaan secara fleksibel untuk mencapai pelbagai keperluan pertanyaan yang kompleks. Pada masa yang sama, kami juga mempelajari cara menggunakan pembina pertanyaan Laravel untuk menulis penyataan pertanyaan pangkalan data, dan memproses serta mengeluarkan hasil pertanyaan.
Atas ialah kandungan terperinci Kumpulan Laravel bertanya beberapa rekod pertama. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!