आप पहचान कॉलम अपडेट नहीं कर सकते।
SQL सर्वर पहचान कॉलम को अपडेट करने की अनुमति नहीं देता है, इसके विपरीत आप अपडेट स्टेटमेंट के साथ अन्य कॉलम के साथ क्या कर सकते हैं।
हालांकि समान प्रकार की आवश्यकता को प्राप्त करने के लिए कुछ विकल्प हैं।
- जब नए रिकॉर्ड के लिए पहचान कॉलम मान को अपडेट करने की आवश्यकता हो
DBCC CHECKIDENT का उपयोग करें जो तालिका के लिए वर्तमान पहचान मान की जाँच करता है और यदि आवश्यक हो, तो पहचान मान को बदल देता है।
DBCC CHECKIDENT('tableName', RESEED, NEW_RESEED_VALUE)
- जब मौजूदा रिकॉर्ड के लिए पहचान कॉलम मान को अपडेट करने की आवश्यकता हो
IDENTITY_INSERT का उपयोग करें जो स्पष्ट मानों को तालिका के पहचान कॉलम में सम्मिलित करने की अनुमति देता है।
SET IDENTITY_INSERT YourTable {ON|OFF}
उदाहरण:
-- Set Identity insert on so that value can be inserted into this column
SET IDENTITY_INSERT YourTable ON
GO
-- Insert the record which you want to update with new value in the identity column
INSERT INTO YourTable(IdentityCol, otherCol) VALUES(13,'myValue')
GO
-- Delete the old row of which you have inserted a copy (above) (make sure about FK's)
DELETE FROM YourTable WHERE ID=3
GO
--Now set the idenetity_insert OFF to back to the previous track
SET IDENTITY_INSERT YourTable OFF