Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Melaksanakan Subquery dengan Cekap dengan WHERE IN dalam Laravel?

Bagaimana untuk Melaksanakan Subquery dengan Cekap dengan WHERE IN dalam Laravel?

Mary-Kate Olsen
Lepaskan: 2024-12-09 20:47:11
asal
597 orang telah melayarinya

How to Efficiently Implement a Subquery with WHERE IN in Laravel?

Menggunakan Laravel untuk Melaksanakan Subkueri dengan Klausa WHERE IN

Anda telah meminta kaedah untuk melaksanakan pertanyaan SQL tertentu yang menggunakan subkueri dengan klausa WHERE IN dalam rangka kerja Laravel. Mari kita terokai cara untuk mencapai ini:

Pembina Pertanyaan Laravel

Pembina Pertanyaan Laravel menyediakan sintaks yang elegan untuk membina pertanyaan SQL. Untuk melaksanakan pertanyaan yang disediakan, anda boleh menggunakan kod berikut:

$productIds = ProductCategory::whereIn('category_id', ['223', '15'])->pluck('product_id');
$products = Product::where('active', 1)->whereIn('id', $productIds)->get();
Salin selepas log masuk

Subquery Berasaskan Penutupan

Sebagai alternatif, anda boleh menggunakan berasaskan penutupan subquery:

Products::whereIn('id', function($query){
    $query->select('product_id')
    ->from('product_category')
    ->whereIn('category_id', ['223', '15'])
    ->where('active', 1);
})
->get();
Salin selepas log masuk

Penjelasan:

  • Pendekatan pertama mengambil ID produk yang sepadan dengan subquery dan menggunakannya dalam pertanyaan seterusnya untuk mendapatkan maklumat produk yang berkaitan , memastikan prestasi yang boleh diterima.
  • Pendekatan kedua membina subkueri secara dinamik, iaitu kemudian digabungkan dengan pertanyaan utama menggunakan kaedah whereIn.

Pertimbangan Prestasi:

Anda menunjukkan bahawa prestasi membimbangkan dan menggunakan subkueri sememangnya sesuai untuk kecekapan. Kaedah berasaskan penutupan adalah lebih kompleks sedikit tetapi mungkin menawarkan beberapa faedah prestasi.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Subquery dengan Cekap dengan WHERE IN dalam Laravel?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan