एक कॉलम पर पहचान संपत्ति निम्नलिखित की गारंटी नहीं देती है :
मूल्य की विशिष्टता - प्राथमिक कुंजी या अद्वितीय बाधा या अद्वितीय अनुक्रमणिका का उपयोग करके विशिष्टता को लागू किया जाना चाहिए।
लेन-देन में लगातार मान - कई पंक्तियों को सम्मिलित करने वाले लेन-देन की पंक्तियों के लिए लगातार मान प्राप्त करने की गारंटी नहीं है क्योंकि अन्य समवर्ती सम्मिलन तालिका पर हो सकते हैं। यदि मान लगातार होने चाहिए तो लेन-देन को टेबल पर एक विशेष लॉक का उपयोग करना चाहिए या सीरियल आइसोलेशन स्तर का उपयोग करना चाहिए।
सर्वर पुनरारंभ होने या अन्य विफलताओं के बाद लगातार मान -एसक्यूएल सर्वर प्रदर्शन कारणों से पहचान मूल्यों को कैश कर सकता है और कुछ असाइन किए गए मान डेटाबेस विफलता या सर्वर पुनरारंभ होने के दौरान खो सकते हैं। इसके परिणामस्वरूप डालने पर पहचान मूल्य में अंतराल हो सकता है। यदि अंतराल स्वीकार्य नहीं हैं, तो एप्लिकेशन को NOCACHE विकल्प के साथ अनुक्रम जनरेटर का उपयोग करना चाहिए या प्रमुख मान उत्पन्न करने के लिए अपने स्वयं के तंत्र का उपयोग करना चाहिए।
मूल्यों का पुन:उपयोग - विशिष्ट बीज/वृद्धि के साथ दी गई पहचान संपत्ति के लिए, इंजन द्वारा पहचान मूल्यों का पुन:उपयोग नहीं किया जाता है। यदि कोई विशेष इंसर्ट स्टेटमेंट विफल हो जाता है या यदि इंसर्ट स्टेटमेंट को वापस ले लिया जाता है तो उपभोग किए गए पहचान मान खो जाते हैं और फिर से उत्पन्न नहीं होंगे। इसके परिणामस्वरूप अंतराल हो सकता है जब बाद के पहचान मान उत्पन्न होते हैं।
इसके अलावा,
यदि बार-बार हटाए जाने वाली तालिका के लिए एक पहचान स्तंभ मौजूद है, तो पहचान मानों के बीच अंतराल हो सकता है। अगर यह चिंता का विषय है, तो पहचान संपत्ति का उपयोग न करें। हालांकि, यह सुनिश्चित करने के लिए कि कोई अंतराल नहीं बनाया गया है या मौजूदा अंतराल को भरने के लिए , SET IDENTITY_INSERT ON
के साथ किसी एक को स्पष्ट रूप से दर्ज करने से पहले मौजूदा पहचान मानों का मूल्यांकन करें ।
इसके अलावा, पहचान कॉलम के गुणों की जाँच करें और पहचान वृद्धि मूल्य की जाँच करें। यह 1 होना चाहिए।