Maison > développement back-end > tutoriel php > Comment puis-je obtenir l'ID d'une ligne nouvellement insérée dans MySQL à l'aide de PHP ?

Comment puis-je obtenir l'ID d'une ligne nouvellement insérée dans MySQL à l'aide de PHP ?

Susan Sarandon
Libérer: 2024-12-05 05:28:10
original
805 Les gens l'ont consulté

How Can I Get the ID of a Newly Inserted Row in MySQL Using PHP?

Insérer une ligne dans une table MySQL et récupérer son ID

Lors de l'insertion d'une ligne dans une table MySQL avec un champ ID à incrémentation automatique , l'obtention de l'ID de la ligne insérée peut être cruciale. Cependant, l'intervalle de temps entre l'insertion et la récupération de l'ID peut introduire des erreurs potentielles.

La fonction mysqli_insert_id()

La fonction PHP mysqli_insert_id() fournit une solution à ce problème. problème. Après avoir exécuté une requête INSERT, mysqli_insert_id() renvoie l'ID de la dernière ligne insérée dans la connexion actuelle. Cela élimine le besoin d'interroger à nouveau la base de données ou de s'appuyer sur des conditions de concurrence.

Exemple d'utilisation :

$link = mysqli_connect('127.0.0.1', 'my_user', 'my_pass', 'my_db');

mysqli_query($link, "INSERT INTO mytable (1, 2, 3, 'blah')");

$id = mysqli_insert_id($link);

echo "Inserted Row ID: $id";
Copier après la connexion

Approche alternative : combinaison de requêtes

Alternativement, la méthode LAST_INSERT_ID() de MySQL peut être utilisée pour modifier plusieurs tables en une seule fois. requête lors de l'attribution d'ID uniques :

mysqli_query($link, "INSERT INTO my_user_table ...;
  INSERT INTO my_other_table (`user_id`) VALUES (LAST_INSERT_ID())");
Copier après la connexion

Remarque : Chaque connexion MySQL maintient un outil de suivi d'ID distinct, évitant ainsi les conflits d'ID.

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