Maison > base de données > tutoriel mysql > Comment créer des instructions Insert...Select avec Laravel : solutions Eloquent et Query Builder ?

Comment créer des instructions Insert...Select avec Laravel : solutions Eloquent et Query Builder ?

Susan Sarandon
Libérer: 2024-11-01 02:20:28
original
415 Les gens l'ont consulté

How to Create Insert...Select Statements with Laravel: Eloquent and Query Builder Solutions?

Créer un insert... Sélectionner des instructions dans Laravel

Q : Comment créer un insert... Sélectionnez une instruction à l'aide de l'ORM éloquent de Laravel ou de requêtes ? J'ai du mal à convertir la syntaxe SQL suivante :

<code class="sql">Insert into Demand (Login, Name, ApptTime, Phone, Physician, Location, FormatName, FormatDate, FormatTime, ApptDate, FormatPhone, cellphone)
Select Login, Name, ApptTime, Phone, Physician, Location, FormatName, FormatDate, FormatTime, ApptDate, FormatPhone, cellphone from " . [dbname] . "
    Where " . $where_statement</code>
Copier après la connexion

A : Bien qu'il n'existe pas d'approche directe à une requête dans Laravel dans la plupart des versions, il existe des méthodes alternatives pour obtenir un résultat similaire :

Méthode 1 : Utilisation du SQL brut et des paramètres de liaison

<code class="php">$select = User::where(...)->where(...)->select(['email', 'moneyOwing']);
$bindings = $select->getBindings();

$insertQuery = 'INSERT into user_debt_collection (email, dinero) ' . $select->toSql();

DB::insert($insertQuery, $bindings);</code>
Copier après la connexion

Méthode 2 : Utilisation de insertUsing() (Laravel 5.7 et supérieur)

<code class="php">DB::table('user_debt_collection')->insertUsing(['email', 'dinero'], $select);</code>
Copier après la connexion

Remarque : Ces méthodes vous permettent de réutiliser les liaisons de l'instruction SELECT existante et d'exécuter l'instruction INSERT séparément.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal