Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Melaksanakan Subkueri dengan Klausa WHERE IN dalam Laravel Eloquent?

Bagaimana untuk Melaksanakan Subkueri dengan Klausa WHERE IN dalam Laravel Eloquent?

Barbara Streisand
Barbara Streisandasal
2024-12-06 20:45:16801semak imbas

How to Implement a Subquery with WHERE IN Clause in Laravel Eloquent?

Subkueri dengan WHERE IN dalam Laravel

Dalam Laravel, anda boleh melakukan pertanyaan kompleks menggunakan subkueri. Kes penggunaan biasa ialah subkueri dengan klausa WHERE IN. Artikel ini menunjukkan cara untuk melaksanakan jenis pertanyaan ini dengan berkesan.

Pertimbangkan pertanyaan SQL berikut:

SELECT 
    `p`.`id`,
    `p`.`name`, 
    `p`.`img`, 
    `p`.`safe_name`, 
    `p`.`sku`, 
    `p`.`productstatusid` 
FROM `products` p 
WHERE `p`.`id` IN (
    SELECT 
        `product_id` 
    FROM `product_category`
    WHERE `category_id` IN ('223', '15')
)
AND `p`.`active`=1

Menggunakan ORM Eloquent Laravel, anda boleh mencapai pertanyaan ini dengan kod berikut:

Products::whereIn('id', function($query){
    $query->select('paper_type_id')
    ->from(with(new ProductCategory)->getTable())
    ->whereIn('category_id', ['223', '15'])
    ->where('active', 1);
})
->get();

Dalam contoh ini, kita mulakan dengan membuat pertanyaan pada model 'Produk' ('Produk::whereIn(...)'). Klausa 'whereIn' menyatakan bahawa kami ingin menapis 'Produk' berdasarkan medan 'id', yang harus disertakan dalam hasil yang dikembalikan oleh subkueri.

Subkueri itu sendiri ditakrifkan menggunakan fungsi tanpa nama ('$query => ...'). Subquery ini memilih medan 'paper_type_id' daripada jadual 'product_category', yang diandaikan tersedia melalui perhubungan dengan model 'ProductCategory'. Nama jadual diperoleh menggunakan kaedah 'with(...)->getTable()'.

Dalam subquery, kami menambah syarat untuk menapis hasil berdasarkan medan 'category_id' dan memastikan bahawa Medan 'aktif' ditetapkan kepada 1. Syarat ini membantu mengecilkan kategori produk untuk dimasukkan dalam keputusan akhir.

Dengan menggunakan pendekatan ini, anda boleh dengan cekap dapatkan semula produk yang memenuhi kriteria yang dikehendaki tanpa perlu melakukan penyertaan yang mahal.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Subkueri dengan Klausa WHERE IN dalam Laravel Eloquent?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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