Maison >base de données >tutoriel mysql >Comment puis-je modifier les colonnes d'identité dans SQL Server ?

Comment puis-je modifier les colonnes d'identité dans SQL Server ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2025-01-07 13:56:40548parcourir

How Can I Modify Identity Columns in SQL Server?

Mise à jour des colonnes d'identité dans SQL Server : un guide complet

Lorsque vous travaillez avec des bases de données SQL Server, vous pouvez rencontrer une situation dans laquelle vous devez modifier la colonne identité. Dans cet article, nous explorerons les options disponibles pour répondre à cette exigence et fournirons une explication détaillée des limitations et des alternatives.

L'impossibilité de mettre à jour les colonnes d'identité

Contrairement d'autres colonnes d'une table SQL Server, les colonnes d'identité ne peuvent pas être mises à jour directement à l'aide d'une instruction de mise à jour. Cette restriction est due à la nature des colonnes d'identité, qui sont conçues pour s'incrémenter automatiquement à chaque nouvel enregistrement inséré dans la table.

Alternatives à la mise à jour des colonnes d'identité

Bien que les mises à jour directes ne sont pas possibles, il existe des méthodes alternatives pour obtenir des résultats similaires en fonction de vos besoins spécifiques :

1. Mise à jour des valeurs d'identité pour les nouveaux enregistrements

Si vous devez vous assurer que les futurs enregistrements insérés dans une table commencent par une valeur d'identité spécifique, vous pouvez utiliser la commande DBCC CHECKIDENT. Cette commande vous permet de réinitialiser la valeur d'identité actuelle et de spécifier une nouvelle valeur de départ.

Syntaxe :

DBCC CHECKIDENT('tableName', RESEED, NEW_RESEED_VALUE)

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 propriété IDENTITY_INSERT. Cette propriété vous permet de spécifier explicitement la valeur d'identité lors de l'insertion de nouveaux enregistrements.

Syntaxe :

SET IDENTITY_INSERT YourTable {ON|OFF}

Exemple :

-- Turn on IDENTITY_INSERT to allow explicit identity value insertion
SET IDENTITY_INSERT YourTable ON
GO
-- Insert a new record with the desired identity value
INSERT INTO YourTable(IdentityCol, otherCol) VALUES(13,'myValue')
GO
-- Delete the old record with the existing identity value
DELETE FROM YourTable WHERE ID=3
GO
-- Turn off IDENTITY_INSERT to resume automatic identity value increment
SET IDENTITY_INSERT YourTable OFF

En tirant parti de ces techniques, vous pouvez relever efficacement les défis associés à la mise à jour des colonnes d'identité dans SQL Server.

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