Maison >base de données >tutoriel mysql >Comment choisir entre @@IDENTITY, SCOPE_IDENTITY() et OUTPUT pour récupérer les valeurs d'identité de clé primaire ?
Lors de la récupération des valeurs du champ d'identité de clé primaire après l'insertion, les développeurs emploient souvent diverses méthodes. Cet article examine les différences et la pertinence des méthodes @@IDENTITY, SCOPE_IDENTITY() et OUTPUT.
@@IDENTITY renvoie la dernière valeur IDENTITY générée pour n'importe quelle table, quelle que soit la portée. Ce n'est pas sécurisé, ce qui signifie qu'il peut renvoyer des identités à partir d'insertions déclenchées ou d'autres instructions au sein de la session en cours.
SCOPE_IDENTITY() se comporte de la même manière, mais il limite la valeur renvoyée à l'instruction actuelle. et la portée de la connexion. Ainsi, il récupère uniquement les identités générées lors de l'exécution de l'instruction.
La clause OUTPUT de l'instruction INSERT renvoie une table contenant les données insérées dans la table. Cela inclut les valeurs IDENTITY générées :
INSERT INTO #Testing (ID, somedate) OUTPUT INSERTED.* DEFAULT VALUES;
La méthode appropriée dépend des exigences spécifiques :
La méthode OUTPUT n'est pas explicitement sécurisée pour la portée. Il récupère les identités générées dans la portée actuelle, mais si ces identités ont été affectées à d'autres tables, il peut également les renvoyer. Pour une sécurité stricte de la portée, utilisez SCOPE_IDENTITY().
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!