Utilisation de Laravel pour implémenter une sous-requête avec la clause WHERE IN
Vous avez demandé une méthode pour exécuter une requête SQL spécifique qui utilise une sous-requête avec une clause WHERE IN dans le framework Laravel. Explorons comment y parvenir :
Laravel Query Builder
Le Laravel Query Builder fournit une syntaxe élégante pour construire des requêtes SQL. Pour exécuter la requête fournie, vous pouvez utiliser le code suivant :
$productIds = ProductCategory::whereIn('category_id', ['223', '15'])->pluck('product_id'); $products = Product::where('active', 1)->whereIn('id', $productIds)->get();
Sous-requête basée sur la fermeture
Vous pouvez également utiliser une requête basée sur la fermeture sous-requête :
Products::whereIn('id', function($query){ $query->select('product_id') ->from('product_category') ->whereIn('category_id', ['223', '15']) ->where('active', 1); }) ->get();
Explication :
Considérations sur les performances :
Vous indiquez que les performances sont un problème et que l'utilisation d'une sous-requête est en effet appropriée pour l'efficacité. La méthode basée sur la fermeture est légèrement plus complexe mais peut offrir certains avantages en termes de performances.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!