परिचय
यह मानते हुए कि आप ग्राहक डेटा वाली एक तालिका बनाए रखते हैं, और आपका बॉस आपसे ग्राहकों की वर्तमान सूची और उनके फ़ोन नंबर भेजने के लिए कहता है। आप आमतौर पर डेटा निकालेंगे और उसे पंक्तियों और स्तंभों के साथ एक स्प्रेडशीट भेजेंगे। आप थोड़ा स्टाइलिश होने का निर्णय भी ले सकते हैं और उसे अधिक लोगों के अनुकूल प्रारूप में आवश्यक जानकारी भेज सकते हैं। SQL सर्वर फ़ंक्शन प्रदान करता है जो हमें गैर-तकनीकी लोगों के पढ़ने के लिए आसान आउटपुट प्रस्तुत करने के लिए तालिकाओं के भीतर डेटा के साथ अंग्रेजी अभिव्यक्तियों को जोड़कर इसे प्राप्त करने की अनुमति देता है। इन कार्यों का अधिक सूक्ष्म उपयोग भी किया जा सकता है।
CONCAT फ़ंक्शन
CONCAT फ़ंक्शन दो या अधिक स्ट्रिंग तर्कों को स्वीकार करता है और ऐसे स्ट्रिंग्स के संयोजन को एकल व्यंजक के रूप में लौटाता है। यह उपयोगी हो सकता है यदि आप विभिन्न स्तंभों की सामग्री को एकल अभिव्यक्ति के रूप में प्रदर्शित करना चाहते हैं। इस फ़ंक्शन का उपयोग करने का एक सरल उदाहरण लिस्टिंग 1 में दिखाया गया है।
-- Listing 1: Simple CONCAT Statement select CONCAT('This','Function','joins','strings.') as statement1; select CONCAT('This ','Function ','joins ','strings.') as statement2; select CONCAT('This',' ','Function',' ','joins',' ','strings') as statement
चित्र 1 में दिए गए रिक्त स्थान और परिणामों का उपयोग करके इस कथन की विविधताओं पर ध्यान दें।
अंजीर। 1. सरल CONCAT कथन
यदि हम INT डेटा प्रकार के इनपुट मान के साथ CONCAT स्टेटमेंट का उपयोग करने का प्रयास करते हैं, तो SQL सर्वर एक अंतर्निहित रूपांतरण करता है और फिर भी एक स्ट्रिंग आउटपुट देता है जैसा कि चित्र 2 में दिखाया गया है। हम पुष्टि कर सकते हैं कि वास्तव में यही हो रहा है। सूची 2 में दिए गए कथन का विवरण। सबसे पहले, उस तालिका की संरचना पर एक नज़र डालें जिसमें हम रुचि रखते हैं। चित्र 2 हमें दिखाता है कि फ़ोन नंबर# और FirstTranDate कॉलम क्रमशः BIGINT और DATETIME कॉलम हैं।
अंजीर। 2. ग्राहक तालिका की संरचना
-- Listing 2: Implicit Conversion When using CONCAT (BIGINT) USE EXAM GO SELECT CONCAT(firstname , ' ' ,lastname , '''s ' , 'Phone number is ' ,phonenumber1) FROM CUSTOMER;
निष्पादन योजना पर एक त्वरित नज़र डालने से हमें पता चलता है कि SQL सर्वर एक अंतर्निहित रूपांतरण करता है PhoneNumber1 कॉलम पर। यह वही होगा यदि कॉलम दिनांक डेटा प्रकार था जैसा कि लिस्टिंग 4 और अंजीर में दिखाया गया है। 4. CONCAT फ़ंक्शन चित्र 6 में दिखाए गए चार्ट में उल्लिखित नियमों के आधार पर अंतर्निहित रूपांतरण करता है।
अंजीर। 3. BIGINT डेटा प्रकार का VARCHAR में निहित रूपांतरण
-- Listing 3: Implicit Conversion When using CONCAT (DATETIME) USE EXAM GO SELECT FirstTranDate, CONCAT(FirstName , ' ' ,LastName , '''s ' , 'first transaction date is ' ,FirstTranDate) as STMT FROM CUSTOMER;
अंजीर। 4. . का निहित रूपांतरण DATETIME डेटा प्रकार VARCHAR के लिए
अंजीर। 5. BIGINT डेटा प्रकार का VARCHAR में निहित रूपांतरण
अंजीर। 6. SQL सर्वर में डेटा प्रकार रूपांतरण
इस फ़ंक्शन के लिए प्राथमिक उपयोग का मामला ऊपर दिए गए प्रदर्शनों से निकाला जा सकता है। एक उदाहरण एक ऐसा मामला होगा जहां कुछ जानकारी को डैशबोर्ड या वेब पेज पर अधिक अनुकूल भाषा में प्रदर्शित करने की आवश्यकता होती है, जिसमें कई कॉलम या अलग-अलग तालिकाओं के डेटा का उपयोग किया जाता है।
CONCAT_WS फ़ंक्शन
CONCAT_WS फ़ंक्शन CONCAT फ़ंक्शन का विस्तार है। यह हमें वांछित विभाजक को पहले पैरामीटर के रूप में निर्दिष्ट करने की अनुमति देता है। लिस्टिंग 4 हमें पहले लिस्टिंग 1 में इस्तेमाल किए गए बयानों में से एक का संशोधन दिखाता है।
--Listing 4 Using CONCAT_WS SELECT CONCAT('This',' ','Function',' ','joins',' ','strings') AS statement; SELECT CONCAT('This',' ','Function',' ','joins',' ','strings') AS statement; SELECT CONCAT_WS(' ','This','Function','joins','strings') AS statement;
ध्यान दें कि CONCAT_WS प्रत्येक तर्क के बाद एक स्पेस को एक तर्क के रूप में पेश करने की तुलना में एक विभाजक के रूप में स्पेस के साथ एक स्टेटमेंट बनाना आसान बनाता है।
--Listing 5 Using CONCAT_WS with Columns USE EXAM GO SELECT CONCAT(firstname , ' ' ,lastname , '''s ' , 'Phone number is ' ,phonenumber1) FROM CUSTOMER; USE EXAM GO SELECT CONCAT_WS(' ',firstname ,lastname , '''s ' , 'Phone number is' ,phonenumber1) FROM CUSTOMER;
“+” चिह्न के साथ संयोजन
CONCAT फ़ंक्शन बहुत सरल तरीके से जो करता है उसे प्राप्त करने के लिए SQL सर्वर "+" चिह्न के उपयोग का समर्थन करता है। यह दृष्टिकोण आमतौर पर टी-एसक्यूएल स्टेटमेंट उत्पन्न करने के लिए उपयोग किया जाता है जब आपको बड़ी संख्या में ऑब्जेक्ट्स पर संचालन करने की आवश्यकता होती है। लिस्टिंग 7 से पता चलता है कि हम परीक्षा डेटाबेस में सभी तालिकाओं के लिए सांख्यिकी अद्यतन बैच कैसे उत्पन्न कर सकते हैं।
-- Listing 6 Generating Update Stats Statements USE Exam GO SELECT 'UPDATE STATISTICS ' + name + ' WITH SAMPLE 25 PERCENT;' as STMT from sys.tables ; SELECT 'UPDATE STATISTICS [' + name + '] WITH SAMPLE 25 PERCENT;' as STMT from sys.tables ; GO
दूसरे कथन में वर्गाकार कोष्ठकों पर ध्यान दें। रिक्त स्थान या विशेष वर्णों वाले सिस्टम ऑब्जेक्ट के साथ व्यवहार करते समय यह उपयोगी होता है।
-- Listing 7 Generating Create User Statements USE MASTER GO SELECT 'CREATE USER [' + LOGINNAME + '] FOR LOGIN [' + LOGINNAME + '] ;' AS STMT FROM SYSLOGINS WHERE LOGINNAME NOT LIKE '#%'; GO USE EXAM GO CREATE USER [sa] FOR LOGIN [sa] ; CREATE USER [EPG-KIGIRI\ekocauris] FOR LOGIN [EPG-KIGIRI\ekocauris] ; CREATE USER [KAIROSAFRIKA\kigiri] FOR LOGIN [KAIROSAFRIKA\kigiri] ; CREATE USER [NT SERVICE\SQLWriter] FOR LOGIN [NT SERVICE\SQLWriter] ; CREATE USER [NT SERVICE\Winmgmt] FOR LOGIN [NT SERVICE\Winmgmt] ; CREATE USER [NT Service\MSSQL$I2019] FOR LOGIN [NT Service\MSSQL$I2019] ; CREATE USER [NT AUTHORITY\SYSTEM] FOR LOGIN [NT AUTHORITY\SYSTEM] ; CREATE USER [NT SERVICE\SQLAgent$I2019] FOR LOGIN [NT SERVICE\SQLAgent$I2019] ; CREATE USER [NT SERVICE\SQLTELEMETRY$I2019] FOR LOGIN [NT SERVICE\SQLTELEMETRY$I2019] ; CREATE USER [KAIROSAFRIKA\sberko] FOR LOGIN [KAIROSAFRIKA\sberko] ; GO
एक बार आउटपुट उत्पन्न होने के बाद, इसका उपयोग किसी भी वांछित डेटाबेस में उपयोगकर्ता बनाने के लिए किया जा सकता है जैसा कि लिस्टिंग 7 में दिखाया गया है। ध्यान दें कि हमने लॉगिन नामों के लिए एक फ़िल्टर जोड़ा है जिसमें हम रुचि रखते हैं। इस दृष्टिकोण का उपयोग सभी प्रकार के बयानों को उत्पन्न करने के लिए किया जा सकता है। और उसी सत्र के भीतर ऐसे बयानों को बुलाओ। एक अधिक जटिल उदाहरण निम्नलिखित कथन हैं जो किसी भी डेटाबेस में सभी अनुक्रमणिका को रचनात्मक रूप से पुनर्निर्माण करते हैं। (सूची 8 और 9 देखें)।
--Listing 8 Generating Index Rebuild Statements USE EXAM GO CREATE TABLE #INDTAB (ID SMALLINT IDENTITY(1,1), REBUILDSTMT NVARCHAR(600)) INSERT INTO #INDTAB SELECT 'SET QUOTED_IDENTIFIER ON; ALTER INDEX [' + B.NAME + '] ON [' + SCHEMA_NAME(C.SCHEMA_ID) + '].[' + OBJECT_NAME(A.OBJECT_ID) + '] REBUILD WITH (ONLINE = OFF ,FILLFACTOR=80 ,SORT_IN_TEMPDB=ON ,PAD_INDEX = ON , STATISTICS_NORECOMPUTE = OFF);' --INTO #INDTAB FROM SYS.DM_DB_INDEX_PHYSICAL_STATS (DB_ID(), NULL, NULL, NULL, NULL) AS A JOIN SYS.INDEXES AS B JOIN SYS.OBJECTS AS C ON B.OBJECT_ID = C.OBJECT_ID ON A.OBJECT_ID = B.OBJECT_ID AND A.INDEX_ID = B.INDEX_ID WHERE AVG_FRAGMENTATION_IN_PERCENT > 30 ; SELECT * FROM #INDTAB; GO DROP TABLE #INDTAB; GO --Listing 9 Generating and Executing Index Rebuild Statements USE EXAM GO CREATE TABLE #INDTAB (ID SMALLINT IDENTITY(1,1), REBUILDSTMT NVARCHAR(600)) INSERT INTO #INDTAB SELECT 'SET QUOTED_IDENTIFIER ON; ALTER INDEX [' + B.NAME + '] ON [' + SCHEMA_NAME(C.SCHEMA_ID) + '].[' + OBJECT_NAME(A.OBJECT_ID) + '] REBUILD WITH (ONLINE = OFF ,FILLFACTOR=80 ,SORT_IN_TEMPDB=ON ,PAD_INDEX = ON , STATISTICS_NORECOMPUTE = OFF);' --INTO #INDTAB FROM SYS.DM_DB_INDEX_PHYSICAL_STATS (DB_ID(), NULL, NULL, NULL, NULL) AS A JOIN SYS.INDEXES AS B JOIN SYS.OBJECTS AS C ON B.OBJECT_ID = C.OBJECT_ID ON A.OBJECT_ID = B.OBJECT_ID AND A.INDEX_ID = B.INDEX_ID WHERE AVG_FRAGMENTATION_IN_PERCENT > 30 ; GO DECLARE @SQL NVARCHAR(4000); SELECT @SQL= REBUILDSTMT FROM #INDTAB ; PRINT @SQL EXEC SP_EXECUTESQL @SQL; GO DROP TABLE #INDTAB; GO
लिस्टिंग 10 में क्वेरी से पता चलता है कि हम स्ट्रिंग्स को स्ट्रिंग्स में स्पष्ट रूप से परिवर्तित तिथियों के साथ कैसे जोड़ सकते हैं। स्ट्रिंग संयोजन एक सामान्य बैकअप पथ चर उत्पन्न करने के लिए उपयोग किया जाता है जिसे बाद में SP_MSFOREACHDB फ़ंक्शन के भीतर उपयोग किया जाता है।
--Listing 10 Generating a Common Backup Path EXEC SP_MSFOREACHDB @COMMAND1=' DECLARE @BACKUP SYSNAME SET @BACKUP=N''G:\BACKUP\?''+CONVERT(NVARCHAR,GETDATE(),112)+N''.BAK'' USE [?] IF ''?'' NOT IN ("MODEL","TEMPDB") BEGIN BACKUP DATABASE ? TO DISK = @BACKUP WITH INIT , NOUNLOAD , COMPRESSION, NAME = N''?'', NOSKIP , NOFORMAT END'
निष्कर्ष
इस लेख में, हमने SQL सर्वर में संयोजन का उपयोग करने के कुछ तरीके दिखाए हैं। हमने CONCAT फ़ंक्शन, CONCAT_WS फ़ंक्शन और "+" चिह्न के उपयोग के उदाहरण दिए हैं। सभी तीन विधियां विभिन्न स्तंभों से मूल्यों को जोड़कर या केवल वांछित लोगों के अनुकूल प्रारूप में जानकारी प्रदर्शित करने के लिए बयान तैयार करने में बहुत उपयोगी हो सकती हैं। Microsoft दस्तावेज़ीकरण में इन फ़ंक्शंस के सिंटैक्स और क्षमताओं के बारे में अधिक जानकारी है।
संदर्भ
कास्ट और कन्वर्ट (ट्रांजैक्ट-एसक्यूएल)
कॉनकैट ट्रांजैक्ट-एसक्यूएल
Concat_ws ट्रांजैक्ट-एसक्यूएल
स्ट्रिंग संयोजन