SQL सर्वर में, आप T-SQL का उपयोग कर सकते हैं IDENT_CURRENT() किसी निर्दिष्ट तालिका के लिए उत्पन्न अंतिम पहचान मान या किसी पहचान स्तंभ पर दृश्य को वापस करने के लिए कार्य करता है। उत्पन्न अंतिम पहचान मूल्य किसी भी सत्र और किसी भी क्षेत्र के लिए हो सकता है।
सिंटैक्स
वाक्य रचना इस प्रकार है:
IDENT_CURRENT('table_or_view' ) table_or_view तर्क तालिका या दृश्य का नाम है जिसका पहचान मूल्य लौटाया गया है।
उदाहरण 1 - मूल उपयोग
यहां एक बुनियादी कोड उदाहरण दिया गया है।
सिलेक्ट IDENT_CURRENT('Pets') AS परिणाम; परिणाम:
+----------+| परिणाम ||----------|| 3 |+----------+
इस मामले में, वर्तमान पहचान मान 3 है।
यहां एक और क्वेरी है जो अधिक तालिकाओं की जांच करती है।
चुनें IDENT_CURRENT('Pets') AS पेट्स, IDENT_CURRENT('BestFriends') AS bestFriends, IDENT_CURRENT('Cities') AS City; परिणाम:
+----------+----------+| पालतू जानवर | बेस्टफ्रेंड्स | शहर ||----------+---------------+----------|| 3 | 121 | 180 |+-----------+---------------+----------+
उदाहरण 2 - स्कीमा सहित
आप स्कीमा को तर्क में भी शामिल कर सकते हैं।
सिलेक्ट IDENT_CURRENT('dbo.Pets') AS परिणाम; परिणाम:
+----------+| परिणाम ||----------|| 3 |+----------+
उदाहरण 3 - डालने के बाद
इस उदाहरण में, मैं पालतू जानवर . में दो और पंक्तियाँ सम्मिलित करता हूँ तालिका, फिर चुनें IDENT_CURRENT() फिर से।
INSERT INTO Pets (PetName)VALUES ('ब्रायन'), ('Alf'); चयन IDENT_CURRENT('dbo.Pets') AS परिणाम; परिणाम:
+----------+| परिणाम ||----------|| 5 |+----------+
यहाँ तालिका कैसी दिखती है:
पालतू जानवरों से *चुनें;
परिणाम:
+-----------+-----------+| पेटीड | पेटनाम ||-----------+---------------|| 1 | होमर || 2 | फेलिक्स || 3 | रफ || 4 | ब्रायन || 5 | अल्फ |+-----------+-----------+
पेटआईड कॉलम पहचान कॉलम है। इसका बीज मूल्य 1 है, और इसका वृद्धि मूल्य भी 1 है।
इस तालिका को बनाने के लिए उपयोग किए गए कोड के लिए SQL सर्वर में पहचान () संपत्ति का उपयोग कैसे करें देखें।
उदाहरण 4 - डेटाबेस में सभी तालिकाओं की जांच करें
यहां डेटाबेस में सभी तालिकाओं को उनके पहचान बीज मूल्य के लिए जांचने का एक उदाहरण दिया गया है।
INFORMATION_SCHEMA से TABLE_SCHEMA, TABLE_NAME, IDENT_CURRENT(TABLE_SCHEMA + '.' + TABLE_NAME) को IDENT_CURRENT के रूप में चुनें।परिणाम:
+----------------+----------------+--------------- -----+| TABLE_SCHEMA | TABLE_NAME | IDENT_CURRENT ||---------------------+----------------+--------------- ----|| डीबीओ | बाधा परीक्षण | 17 || डीबीओ | घटना | 1 || डीबीओ | स्कोरबोर्ड | 8 || डीबीओ | पालतू जानवर | 5 || डीबीओ | बेस्टफ्रेंड्स | 121 || डीबीओ | शहर | 180 || डीबीओ | रंग | 6 || डीबीओ | t6 | 1 || डीबीओ | t7 | 100 |+----------------+----------------+--------------- ----+रिटर्न वैल्यू के बारे में
IDENT_CURRENT(). के लिए वापसी मानnumeric(@@MAXPRECISION,0))है . इसका मतलब है कि यह एक निश्चित सटीकता और पैमाने के साथ एक संख्यात्मक डेटा प्रकार है।सटीकता सर्वर पर निर्भर करती है।
@@MAXPRECISIONतर्क दशमलव और संख्यात्मक डेटा प्रकारों द्वारा उपयोग किए गए स्तर को वर्तमान में सर्वर में सेट करता है। सटीक दशमलव अंकों की अधिकतम कुल संख्या निर्दिष्ट करता है (इसमें दशमलव बिंदु के बाईं और दाईं ओर वाले अंक शामिल हैं)।दूसरा तर्क
0. के पैमाने को निर्दिष्ट करता है , जिसका अर्थ है कि दशमलव स्थान के दाईं ओर कोई दशमलव अंक नहीं हैं।आप अपने सर्वर पर वर्तमान में निर्धारित सटीक स्तर को खोजने के लिए निम्न क्वेरी चला सकते हैं:
चुनें @@MAX_PRECISION AS [अधिकतम सटीक];मेरे सिस्टम पर यह रहा परिणाम:
+-----------------+| मैक्स प्रेसिजन ||-----------------|| 38 |+-----------------+पहचान कॉलम बनाना
आप
IDENTITY(). का उपयोग करके एक पहचान कॉलम बना सकते हैं आपकेCREATE TABLE. में संपत्ति याALTER TABLEबयान।पहचान कॉलम बनाने का दूसरा तरीका है
IDENTITY()समारोह। यह आपकोSELECT INTO. का उपयोग करते समय एक पहचान कॉलम बनाने में सक्षम बनाता है डेटा को एक स्रोत से दूसरे स्रोत में स्थानांतरित करने के लिए कथन।@@IDENTITY और SCOPE_IDENTITY() के साथ अंतर
IDENT_CURRENT()फ़ंक्शन@@IDENTITY. के समान है औरSCOPE_IDENTITY(), लेकिन कुछ अंतर हैं।
@@IDENTITYऔरSCOPE_IDENTITY()किसी भी . में जेनरेट किया गया अंतिम पहचान मान लौटाएं मौजूदा सत्र में तालिका हालाँकि, इन दोनों कार्यों के बीच अंतर यह है किSCOPE_IDENTITYमान केवल वर्तमान दायरे में लौटाता है, जबकि@@IDENTITYएक विशिष्ट दायरे तक सीमित नहीं है।
IDENT_CURRENT()दूसरी ओर, या . के दायरे तक सीमित नहीं है सत्र। बल्कि, यह एक निर्दिष्ट तालिका . तक सीमित है . यह किसी भी सत्र और किसी भी दायरे में किसी विशिष्ट तालिका के लिए उत्पन्न पहचान मान देता है।SQL सर्वर में IDENT_CURRENT बनाम @@ पहचान बनाम SCOPE_IDENTITY देखें:क्या अंतर है? एक साधारण उदाहरण के लिए जो इन तीन कार्यों के बीच के अंतरों से चलता है।