Maison > base de données > tutoriel mysql > Comment pouvez-vous insérer des lignes et récupérer des données dans une seule requête MySQL ?

Comment pouvez-vous insérer des lignes et récupérer des données dans une seule requête MySQL ?

Mary-Kate Olsen
Libérer: 2024-10-25 04:51:29
original
729 Les gens l'ont consulté

How Can You Insert Rows and Retrieve Data in a Single MySQL Query?

Insérer des lignes et récupérer de nouvelles données dans MySQL

De nombreuses tâches nécessitent l'ajout de nouveaux enregistrements à une base de données et leur accès ultérieur. Traditionnellement, cela implique des opérations d'insertion et de récupération distinctes. Mais saviez-vous qu'il est possible d'accomplir les deux tâches en une seule requête ?

Insertion et sélection atomique de valeurs

La clé réside dans l'utilisation de la fonction LAST_INSERT_ID(). Après avoir exécuté une instruction d'insertion, cette fonction renvoie l'ID généré pour la ligne nouvellement insérée.

Exemple :

Considérons l'exemple fourni dans la question :

<code class="sql">INSERT INTO `items` (`item`, `number`, `state`) 
(SELECT '3', `number`, `state` FROM `item_bug` WHERE `id`='3')</code>
Copier après la connexion

Pour obtenir l'ID de la ligne insérée et récupérer ses autres valeurs, vous pouvez exécuter la requête suivante :

<code class="sql">SELECT * FROM `items` WHERE `id`= LAST_INSERT_ID()</code>
Copier après la connexion

Cette requête récupérera la ligne entière de la table items qui correspond à la dernière ligne insérée.

Avantages :

  • Requête unique pour les deux tâches : Améliore les performances et réduit la complexité du code.
  • Opération atomique : Les deux étapes se déroulent en une seule transaction, garantissant l'intégrité des données.
  • Simplifie la récupération des données : Les développeurs n'ont pas à se soucier de la mémorisation ou gérer les ID de ligne en dehors du contexte de la requête.

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