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!