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
Mary-Kate Olsenoriginal
2024-10-25 04:51:29769parcourir

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>

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>

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!

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