Maison  >  Article  >  développement back-end  >  Comment convertir des requêtes multi-instructions MySQL complexes en Laravel Eloquent ?

Comment convertir des requêtes multi-instructions MySQL complexes en Laravel Eloquent ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-26 04:21:02269parcourir

How to Convert Complex MySQL Multi-Statement Queries to Laravel Eloquent?

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn