Rumah > rangka kerja php > Laravel > Kumpulan Laravel bertanya beberapa rekod pertama

Kumpulan Laravel bertanya beberapa rekod pertama

PHPz
Lepaskan: 2023-05-29 09:08:08
asal
799 orang telah melayarinya

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.

  1. Persediaan

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.

  1. Menulis pernyataan pertanyaan

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

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.

  1. Memproses hasil pertanyaan

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

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.

  1. Hasil keluaran

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

Apabila mengeluarkan keputusan, kami mula-mula mengeluarkan nama kategori, dan kemudian mengeluarkan nama setiap produk dalam senarai ul.

  1. Ringkasan

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!

sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan