Conversion d'une requête multi-instructions MySQL en Laravel Eloquent
Dans une requête MySQL, vous pouvez rencontrer des requêtes multi-instructions complexes impliquant diverses opérations telles que DÉFINIR, PRÉPARER, EXÉCUTER et DÉSALLOCER. La conversion de telles requêtes en Laravel Eloquent peut être difficile.
Solution
Laravel Eloquent ne peut pas exécuter plusieurs instructions ou effectuer des opérations de bas niveau comme DEALLOCATE. Par conséquent, nous devons décomposer la requête en ses composants individuels et les exécuter séparément.
Tout d'abord, exécutez la requête GROUP_CONCAT :
<code class="php">$concatResult = DB::table('item_details') ->selectRaw('GROUP_CONCAT(...) INTO @sql') ->get();</code>
Récupérez la valeur attribuée à la variable @sql :
<code class="php">$sql = DB::selectOne('select @sql')->{'@sql'};</code>
Enfin, composez et exécutez la requête restante dans Eloquent :
<code class="php">ItemDetails::select('item_number', DB::raw('SUM(quantity) as total_quantity')) ->selectRaw($sql) ->groupBy('item_number') ->get();</code>
Cette solution décompose la requête multi-instructions MySQL en morceaux gérables qui peuvent être exécutés séparément dans Laravel Eloquent, obtenir le même résultat que la requête d'origine.
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!