Les colonnes d'identité fournissent des identifiants uniques et séquentiels pour les lignes d'une table de base de données. Par défaut, SQL Server attribue une valeur incrémentielle à cette colonne lors de l'insertion d'une ligne. Cependant, il existe des cas où vous pouvez rencontrer une situation dans laquelle la valeur initiale est indésirablement grande ou entre en conflit avec une relation de table existante.
Les colonnes d'identité peuvent-elles être mises à jour ?
Contrairement aux colonnes normales, les colonnes d'identité ne peuvent pas être directement mises à jour à l'aide d'une instruction UPDATE. SQL Server restreint ces modifications pour préserver leur intégrité séquentielle et éviter les problèmes d'intégrité des données.
Alternatives pour mettre à jour les colonnes d'identité
Bien que la mise à jour directe des colonnes d'identité ne soit pas possible, il existe approches alternatives en fonction de votre scénario spécifique :
1. Ajustement des valeurs d'identité pour les nouveaux enregistrements :
Pour modifier la valeur d'identité des nouveaux enregistrements, suivez les étapes suivantes :
2. Mise à jour des valeurs d'identité pour les enregistrements existants :
Pour mettre à jour la valeur d'identité des enregistrements existants, vous pouvez utiliser la commande IDENTITY_INSERT comme suit :
SET IDENTITY_INSERT YourTable ON INSERT INTO YourTable(IdentityCol, otherCol) VALUES(13,'myValue') DELETE FROM YourTable WHERE ID=3 SET IDENTITY_INSERT YourTable OFF
N'oubliez pas de procéder avec prudence avec cette approche, car la modification des enregistrements existants peut affecter les relations et les contraintes d’intégrité référentielle. Il est recommandé de créer des sauvegardes avant d'effectuer de telles mises à jour.
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!