टी-एसक्यूएल - त्वरित गाइड

1970 में आईबीएम द्वारा विकसित और बाद में SEQUEL को 'SQL' नाम दिया गया, जिसे संरचित क्वेरी लैंग्वेज के लिए विकसित किया गया था।

1986 में, SQL को ANSI (अमेरिकी राष्ट्रीय मानक संस्थान) द्वारा अनुमोदित किया गया था और 1987 में, इसे ISO (अंतर्राष्ट्रीय मानक संगठन) द्वारा अनुमोदित किया गया था।

SQL एक संरचना क्वेरी भाषा है जो सभी RDBMS उत्पादों के लिए एक सामान्य डेटाबेस भाषा है। विभिन्न RDBMS उत्पाद विक्रेताओं ने अपने स्वयं के RDBMS उत्पादों के लिए SQL का विस्तार करके अपनी स्वयं की डेटाबेस भाषा विकसित की है।

T-SQL का मतलब Transact Structure Query Language है जो एक Microsoft उत्पाद है और SQL भाषा का एक विस्तार है।

उदाहरण

MS SQL Server - SQL \ T-SQL

ORACLE - SQL \ PL-SQL

SQL सर्वर डेटा प्रकार एक विशेषता है जो किसी भी वस्तु के डेटा के प्रकार को निर्दिष्ट करता है। प्रत्येक स्तंभ, चर और अभिव्यक्ति SQL सर्वर में संबंधित डेटा प्रकार है। टेबल बनाते समय इन डेटा प्रकारों का उपयोग किया जा सकता है। आप अपनी आवश्यकता के आधार पर टेबल कॉलम के लिए एक विशेष डेटा प्रकार चुन सकते हैं।

SQL सर्वर उपयोग के लिए अन्य प्रकार के डेटा प्रकारों सहित सात श्रेणियां प्रदान करता है।

सटीक न्यूमेरिक प्रकार

प्रकार से सेवा
bigint -9.223.372.036.854.775.808 9.223.372.036.854.775.807
पूर्णांक -+२१४७४८३६४८ 2,147,483,647
SMALLINT -32,768 32,767
tinyint 0 255
बिट 0 1
दशमलव -10 ^ 38 +1 10 ^ 38-1
संख्यात्मक -10 ^ 38 +1 10 ^ 38-1
पैसे -922,337,203,685,477.5808 +922,337,203,685,477.5807
smallmoney -214,748.3648 +214,748.3647

न्यूमेरिक और दशमलव निश्चित परिशुद्धता और स्केल डेटा प्रकार हैं और कार्यात्मक रूप से समतुल्य हैं।

अनुमानित संख्यात्मक प्रकार

प्रकार से सेवा
फ्लोट -1.79 ई + 308 1.79 ई + 308
असली -3.40 ई + 38 ३.४० ई + ३ 38

दिनांक और समय के प्रकार

प्रकार से सेवा

datetime(3.33 मिलीसेकंड सटीकता)

1 जनवरी, 1753 31 दिसंबर, 9999

smalldatetime(1 मिनट सटीकता)

1 जनवरी, 1900 जून ६, २० 6 ९

date(1 दिन की सटीकता। SQL सर्वर 2008 में पेश किया गया)

1 जनवरी, 0001 31 दिसंबर, 9999

datetimeoffset(100 नैनोसेकंड सटीकता। एसक्यूएल सर्वर 2008 में पेश किया गया)

1 जनवरी, 0001 31 दिसंबर, 9999

datetime2(100 नैनोसेकंड सटीकता। में पेश किया गया SQL Server 2008)

1 जनवरी, 0001 31 दिसंबर, 9999

time(100 नैनोसेकंड सटीकता। में पेश किया गया SQL Server 2008)

00: 00: ००.००,००,००० 23: 59: ५९.९९,९९,९९९

चरित्र स्ट्रिंग्स

अनु क्रमांक टाइप और विवरण
1

char

8,000 वर्णों की अधिकतम लंबाई के साथ निश्चित-लंबाई वाला गैर-यूनिकोड वर्ण डेटा।

2

varchar

अधिकतम 8,000 वर्णों के साथ चर-लंबाई वाला गैर-यूनिकोड डेटा।

3

Varchar (max)

231 वर्णों की अधिकतम लंबाई (SQL Server 2005 में प्रस्तुत) के साथ चर-लंबाई वाला गैर-यूनिकोड डेटा।

4

text

2,147,483,647 वर्णों की अधिकतम लंबाई के साथ चर-लंबाई वाला गैर-यूनिकोड डेटा

यूनिकोड चरित्र स्ट्रिंग्स

अनु क्रमांक टाइप और विवरण
1

nchar

4,000 वर्णों की अधिकतम लंबाई के साथ फिक्स्ड-लंबाई यूनिकोड डेटा।

2

nvarchar

4,000 वर्णों की अधिकतम लंबाई के साथ चर-लंबाई यूनिकोड डेटा।

3

Nvarchar (max)

2 की अधिकतम लंबाई के साथ चर लंबाई यूनिकोड डेटा 30 वर्ण (SQL सर्वर 2005 में शुरू)।

4

ntext

चर-लंबाई यूनिकोड डेटा जिसकी अधिकतम लंबाई 1,073,741,823 वर्ण है।

बाइनरी स्ट्रिंग्स

अनु क्रमांक टाइप और विवरण
1

binary

8,000 बाइट की अधिकतम लंबाई के साथ फिक्स्ड-लंबाई बाइनरी डेटा।

2

varbinary

8,000 बाइट्स की अधिकतम लंबाई के साथ चर-लंबाई बाइनरी डेटा।

3

varbinary(max)

चर लंबाई 2 की अधिकतम लंबाई के साथ बाइनरी डेटा 31 बाइट्स (SQL सर्वर 2005 में शुरू)।

4

image

2,147,483,647 बाइट्स की अधिकतम लंबाई के साथ चर-लंबाई बाइनरी डेटा।

अन्य डेटा प्रकार

  • sql_variant - टेक्स्ट, नेक्स्ट और टाइमस्टैम्प को छोड़कर विभिन्न SQL सर्वर समर्थित डेटा प्रकारों के स्टोर वैल्यू।

  • timestamp - एक डेटाबेस-वाइड यूनिक नंबर को स्टोर करता है जो हर बार अपडेट होने के बाद अपडेट हो जाता है।

  • uniqueidentifier - विश्व स्तर पर विशिष्ट पहचानकर्ता (GUID) संग्रहीत करता है।

  • xml- एक्सएमएल डेटा स्टोर। आप एक स्तंभ या एक चर में XML उदाहरण स्टोर कर सकते हैं (SQL Server 2005 में प्रस्तुत)।

  • cursor - एक कर्सर का संदर्भ।

  • table - बाद के प्रसंस्करण के लिए निर्धारित परिणाम को संग्रहीत करता है।

  • hierarchyid - एक चर लंबाई, सिस्टम डेटा प्रकार का उपयोग पदानुक्रम में स्थिति का प्रतिनिधित्व करने के लिए किया जाता है (SQL Server 2008 में प्रस्तुत)।

एक मूल तालिका बनाने में तालिका का नामकरण और उसके कॉलम और प्रत्येक स्तंभ के डेटा प्रकार को परिभाषित करना शामिल है।

SQL सर्वर CREATE TABLE स्टेटमेंट का उपयोग नई तालिका बनाने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित संक्षिप्त विवरण का मूल सिंटैक्स है -

CREATE TABLE table_name( 
   column1 datatype, 
   column2 datatype, 
   column3 datatype, 
   ..... 
   columnN datatype, 
   PRIMARY KEY( one or more columns ));

क्रिएट टेबल वह कीवर्ड है जो डेटाबेस सिस्टम को बताता है कि आप क्या करना चाहते हैं। इस मामले में, आप एक नई तालिका बनाना चाहते हैं। तालिका के लिए अद्वितीय नाम या पहचानकर्ता क्रिएट टेबल स्टेटमेंट का अनुसरण करता है। फिर कोष्ठक में तालिका में प्रत्येक स्तंभ को परिभाषित करने वाली सूची आती है और यह किस प्रकार का डेटा प्रकार है। वाक्यविन्यास निम्नलिखित उदाहरण के साथ समझने के लिए स्पष्ट हो जाता है।

किसी मौजूदा तालिका की एक प्रतिलिपि क्रिएट टेबल स्टेटमेंट और सेलेक्ट स्टेटमेंट के संयोजन का उपयोग करके बनाई जा सकती है। आप अन्य तालिका का उपयोग करके तालिका बनाएं पर संपूर्ण विवरण देख सकते हैं।

उदाहरण

इस उदाहरण में, आइए प्राथमिक कुंजी के रूप में ID के साथ एक ग्राहक तालिका बनाएं और नॉट NULL इस दिशा में सारणी बनाते समय यह दर्शाते हैं कि ये क्षेत्र NULL नहीं हो सकते हैं -

CREATE TABLE CUSTOMERS( 
   ID   INT              NOT NULL, 
   NAME VARCHAR (20)     NOT NULL, 
   AGE  INT              NOT NULL, 
   ADDRESS  CHAR (25) , 
   SALARY   DECIMAL (18, 2),        
   PRIMARY KEY (ID));

आप यह सत्यापित कर सकते हैं कि SQL सर्वर द्वारा प्रदर्शित संदेश को देखकर आपकी तालिका सफलतापूर्वक बनाई गई है, अन्यथा आप निम्न आदेश का उपयोग कर सकते हैं -

exec sp_columns CUSTOMERS

उपरोक्त कमांड निम्न आउटपुट का उत्पादन करता है।

TABLE_QUALIFIER   TABLE_OWNER   TABLE_NAME   COLUMN_NAME   DATA_TYPE   TYPE_NAME
   PRECISION   LENGTH SCALE   RADIX   NULLABLE   REMARKS   COLUMN_DEF   SQL_DATA_TYPE 
   SQL_DATETIME_SUB   CHAR_OCTET_LENGTH   ORDINAL_POSITION   IS_NULLABLE   SS_DATA_TYPE
   
TestDB    dbo    CUSTOMERS   ID        4    int      10   4    0      10     0
   NULL   NULL   4   NULL    NULL      1    NO       56 
   
TestDB    dbo    CUSTOMERS   NAME      12   varchar  20   20   NULL   NULL   0
   NULL   NULL   12   NULL   20        2    NO       39
  
TestDB    dbo    CUSTOMERS   AGE       4    int      10   4    0      10     0
   NULL   NULL   4   NULL    NULL      3    NO       56 
 
TestDB    dbo    CUSTOMERS   ADDRESS   1    char     25   25   NULL   NULL   1
   NULL   NULL   1   NULL    25   4    YES  39  

TestDB    dbo    CUSTOMERS   SALARY    3    decimal  18   20   2      10     1
   NULL   NULL   3   NULL    NULL      5    YES      106

अब आप देख सकते हैं कि ग्राहक तालिका आपके डेटाबेस में उपलब्ध है जिसका उपयोग आप ग्राहकों से संबंधित आवश्यक जानकारी संग्रहीत करने के लिए कर सकते हैं।

SQL सर्वर DROP TABLE स्टेटमेंट का उपयोग टेबल की परिभाषा और उस टेबल के सभी डेटा, इंडेक्स, ट्रिगर्स, बाधाओं और अनुमति विनिर्देशों को हटाने के लिए किया जाता है।

Note - इस कमांड का उपयोग करते समय आपको सावधान रहना होगा क्योंकि एक बार टेबल डिलीट हो जाने के बाद टेबल में उपलब्ध सभी जानकारी भी हमेशा के लिए खो जाएगी।

वाक्य - विन्यास

निम्नलिखित DROP टेबल विवरण का मूल सिंटैक्स है -

DROP TABLE table_name;

उदाहरण

आइए पहले ग्राहक तालिका को सत्यापित करें और फिर हम इसे डेटाबेस से हटा देंगे -

Exec sp_columns CUSTOMERS;

उपरोक्त आदेश निम्न तालिका दिखाता है।

TABLE_QUALIFIER   TABLE_OWNER   TABLE_NAME   COLUMN_NAME   DATA_TYPE   TYPE_NAME
   PRECISION   LENGTH SCALE   RADIX   NULLABLE   REMARKS   COLUMN_DEF   SQL_DATA_TYPE 
   SQL_DATETIME_SUB   CHAR_OCTET_LENGTH   ORDINAL_POSITION   IS_NULLABLE   SS_DATA_TYPE
   
TestDB    dbo    CUSTOMERS   ID        4   int        10   4    0      10     0
   NULL   NULL   4   NULL    NULL      1   NO         56 
   
TestDB    dbo    CUSTOMERS   NAME      12  varchar    20   20   NULL   NULL   0
   NULL   NULL   12   NULL   20        2   NO         39
  
TestDB    dbo    CUSTOMERS   AGE       4   int        10   4    0      10     0
   NULL   NULL   4   NULL    NULL      3   NO         56 
 
TestDB    dbo    CUSTOMERS   ADDRESS   1   char       25   25   NULL   NULL   1
   NULL   NULL   1   NULL    25        4   YES        39  

TestDB    dbo    CUSTOMERS   SALARY   3   decimal     18   20   2      10     1
   NULL   NULL   3   NULL    NULL     5   YES         106

ग्राहक तालिका डेटाबेस में उपलब्ध है, तो हम इसे छोड़ दें। निम्नलिखित उसी के लिए आदेश है।

DROP TABLE CUSTOMERS; 
Command(s) completed successfully.

उपरोक्त कमांड के साथ, आपको कोई पंक्तियाँ नहीं मिलेंगी।

Exec sp_columns CUSTOMERS; 
No rows\data will be displayed

SQL सर्वर INSERT INTO विवरण का उपयोग डेटाबेस में तालिका में डेटा की नई पंक्तियों को जोड़ने के लिए किया जाता है।

वाक्य - विन्यास

निम्नलिखित INSERT INTO स्टेटमेंट के दो मूल सिंटैक्स हैं।

INSERT INTO TABLE_NAME [(column1, column2, column3,...columnN)]   
VALUES (value1, value2, value3,...valueN);

जहां column1, column2, ... columnN उस कॉलम के नाम हैं जिसमें आप डेटा डालना चाहते हैं।

यदि आप तालिका के सभी स्तंभों के लिए मान जोड़ रहे हैं, तो आपको SQL क्वेरी में कॉलम (नामों) को निर्दिष्ट करने की आवश्यकता नहीं है। लेकिन सुनिश्चित करें कि मानों का क्रम उसी क्रम में है जैसा कि तालिका में कॉलम है। निम्नलिखित SQL INSERT INTO सिंटैक्स है -

INSERT INTO TABLE_NAME VALUES (value1,value2,value3,...valueN);

उदाहरण

निम्नलिखित कथन ग्राहक तालिका में छह रिकॉर्ड बनाएंगे -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );
  
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 
 
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 );

वाक्य - विन्यास

आप दूसरे सिंटैक्स का उपयोग करके ग्राहक तालिका में एक रिकॉर्ड बना सकते हैं -

INSERT INTO CUSTOMERS VALUES (7, 'Muffy', 24, 'Indore', 10000.00 );

उपरोक्त सभी कथन ग्राहक तालिका में निम्नलिखित अभिलेख प्रस्तुत करेंगे -

ID  NAME       AGE         ADDRESS              SALARY 
1   Ramesh     32          Ahmedabad            2000.00 
2   Khilan     25          Delhi                1500.00 
3   kaushik    23          Kota                 2000.00 
4   Chaitali   25          Mumbai               6500.00 
5   Hardik     27          Bhopal               8500.00 
6   Komal      22          MP                   4500.00 
7   Muffy      24          Indore               10000.00

दूसरी तालिका का उपयोग करके एक तालिका को आबाद करें

आप किसी तालिका में डेटा का चयन किसी अन्य तालिका पर सेलेक्ट स्टेटमेंट के माध्यम से कर सकते हैं, बशर्ते कि किसी अन्य तालिका में फ़ील्ड्स का एक सेट हो, जिसे पहले तालिका को पॉप्युलेट करना आवश्यक हो। निम्नलिखित वाक्य रचना है -

INSERT INTO first_table_name  
   SELECT column1, column2, ...columnN  
      FROM second_table_name 
      [WHERE condition];

एस क्यू एल सर्वर SELECTविवरण का उपयोग डेटा को डेटाबेस तालिका से लाने के लिए किया जाता है जो परिणाम तालिका के रूप में डेटा लौटाता है। इन परिणाम तालिकाओं को कहा जाता हैresult-sets

वाक्य - विन्यास

निम्नलिखित चयन कथन का मूल सिंटैक्स है -

SELECT column1, column2, columnN FROM table_name;

जहां, column1, column2 ... एक तालिका के क्षेत्र हैं, जिनके मान आप प्राप्त करना चाहते हैं। यदि आप क्षेत्र में उपलब्ध सभी क्षेत्रों को लाना चाहते हैं, तो आप निम्नलिखित सिंटैक्स का उपयोग कर सकते हैं -

SELECT * FROM table_name;

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           2000.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              8500.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

निम्नलिखित आदेश एक उदाहरण है, जो ग्राहकों की तालिका में उपलब्ध ग्राहकों के आईडी, नाम और वेतन क्षेत्रों को प्राप्त करेगा -

SELECT ID, NAME, SALARY FROM CUSTOMERS;

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME          SALARY 
1   Ramesh        2000.00 
2   Khilan        1500.00 
3   kaushik       2000.00 
4   Chaitali      6500.00 
5   Hardik        8500.00 
6   Komal         4500.00 
7   Muffy         10000.00

यदि आप ग्राहक तालिका के सभी क्षेत्रों को लाना चाहते हैं, तो निम्नलिखित प्रश्न का उपयोग करें -

SELECT * FROM CUSTOMERS;

उपरोक्त निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS              SALARY 
1   Ramesh     32        Ahmedabad            2000.00 
2   Khilan     25        Delhi                1500.00 
3   kaushik    23        Kota                 2000.00 
4   Chaitali   25        Mumbai               6500.00 
5   Hardik     27        Bhopal               8500.00 
6   Komal      22        MP                   4500.00 
7   Muffy      24        Indore               10000.00

SQL सर्वर UPDATE क्वेरी का उपयोग किसी तालिका में मौजूदा रिकॉर्ड को संशोधित करने के लिए किया जाता है।

आप चयनित पंक्तियों को अद्यतन करने के लिए UPDATE क्वेरी के साथ जहां खंड का उपयोग कर सकते हैं अन्यथा सभी पंक्तियाँ प्रभावित होंगी।

वाक्य - विन्यास

निम्नलिखित खंड के साथ अद्यतन क्वेरी का मूल सिंटैक्स है -

UPDATE table_name 
SET column1 = value1, column2 = value2...., columnN = valueN 
WHERE [condition];

आप AND या ऑपरेटर्स का उपयोग करके N की संख्या को जोड़ सकते हैं।

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           2000.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              8500.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

निम्नलिखित आदेश एक उदाहरण है, जो उस ग्राहक के लिए ADDRESS को अपडेट करेगा, जिसकी आईडी 6 है -

UPDATE CUSTOMERS 
SET ADDRESS = 'Pune' 
WHERE ID = 6;

ग्राहक तालिका में अब निम्नलिखित रिकॉर्ड होंगे -

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           2000.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              8500.00 
6   Komal      22        Pune                4500.00 
7   Muffy      24        Indore              10000.00

यदि आप CUSTOMERS तालिका में सभी ADDRESS और SALARY स्तंभ मानों को संशोधित करना चाहते हैं, तो आपको WHERE क्लॉज़ का उपयोग करने की आवश्यकता नहीं है। अद्यतन क्वेरी निम्नानुसार होगी -

UPDATE CUSTOMERS 
SET ADDRESS = 'Pune', SALARY = 1000.00;

ग्राहक तालिका में अब निम्नलिखित रिकॉर्ड होंगे।

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Pune             1000.00 
2   Khilan     25        Pune             1000.00 
3   kaushik    23        Pune             1000.00 
4   Chaitali   25        Pune             1000.00 
5   Hardik     27        Pune             1000.00 
6   Komal      22        Pune             1000.00 
7   Muffy      24        Pune             1000.00

SQL सर्वर DELETE क्वेरी का उपयोग किसी तालिका से मौजूदा रिकॉर्ड को हटाने के लिए किया जाता है।

आपको चयनित पंक्तियों को हटाने के लिए DELETE क्वेरी के साथ WHERE क्लॉज़ का उपयोग करना होगा, अन्यथा सभी रिकॉर्ड हटा दिए जाएंगे।

वाक्य - विन्यास

निम्नलिखित क्लैट के साथ DELETE क्वेरी का मूल सिंटैक्स निम्नलिखित है -

DELETE FROM table_name 
WHERE [condition];

आप AND या ऑपरेटर्स का उपयोग करके N की संख्या को जोड़ सकते हैं।

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

निम्नलिखित आदेश एक उदाहरण है, जो एक ग्राहक को हटा देगा, जिसकी आईडी 6 है -

DELETE FROM CUSTOMERS 
WHERE ID = 6;

ग्राहक तालिका में अब निम्नलिखित रिकॉर्ड होंगे।

ID  NAME       AGE       ADDRESS              SALARY 
1   Ramesh     32        Ahmedabad            2000.00 
2   Khilan     25        Delhi                1500.00 
3   kaushik    23        Kota                 2000.00 
4   Chaitali   25        Mumbai               6500.00 
5   Hardik     27        Bhopal               8500.00 
7   Muffy      24        Indore               10000.00

यदि आप CUSTOMERS तालिका से सभी रिकॉर्ड हटाना चाहते हैं, तो आपको WHERE क्लॉज़ का उपयोग करने की आवश्यकता नहीं है। DELETE क्वेरी निम्नानुसार होगी -

DELETE FROM CUSTOMERS;

ग्राहक तालिका में अब कोई रिकॉर्ड नहीं होगा।

एमएस SQL ​​सर्वर WHERE एक तालिका से डेटा प्राप्त करते समय या एक से अधिक तालिकाओं के साथ जुड़ने पर एक स्थिति निर्दिष्ट करने के लिए क्लॉज का उपयोग किया जाता है।

यदि दी गई स्थिति संतुष्ट है, केवल तभी वह तालिका से एक विशिष्ट मूल्य लौटाता है। आपको अभिलेखों को फ़िल्टर करने और केवल आवश्यक रिकॉर्ड लाने के लिए WHERE क्लॉज़ का उपयोग करना होगा।

WHERE क्लॉज का उपयोग केवल SELECT स्टेटमेंट में ही नहीं किया जाता है, बल्कि इसका उपयोग UPDATE, DELETE स्टेटमेंट, आदि में भी किया जाता है, जिसे हम बाद के अध्यायों में जाँचेंगे।

वाक्य - विन्यास

निम्नलिखित कथन का मूल सिंटैक्स निम्नलिखित है, जहां -

SELECT column1, column2, columnN  
FROM table_name 
WHERE [condition]

आप तुलना या तार्किक संचालकों जैसे>, <, =, LIKE, NOT, आदि का उपयोग करके एक शर्त निर्दिष्ट कर सकते हैं। निम्नलिखित उदाहरण इस अवधारणा को स्पष्ट करेगा।

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

निम्नलिखित आदेश एक उदाहरण है जो ग्राहक तालिका से आईडी, नाम और वेतन फ़ील्ड प्राप्त करेगा जहां वेतन 2000 से अधिक है।

SELECT ID, NAME, SALARY  
FROM CUSTOMERS 
WHERE SALARY > 2000;

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       SALARY 
4   Chaitali   6500.00 
5   Hardik     8500.00 
6   Komal      4500.00 
7   Muffy      10000.00

निम्नलिखित आदेश एक उदाहरण है, जो 'हार्दिक' नाम के ग्राहक के लिए ग्राहक तालिका से आईडी, नाम और वेतन फ़ील्ड प्राप्त करेगा। यह ध्यान रखना महत्वपूर्ण है कि सभी तार एकल उद्धरण ('') के अंदर दिए जाने चाहिए, जबकि संख्यात्मक मान बिना किसी उद्धरण के दिए जाने चाहिए जैसे कि उपरोक्त उदाहरण में -

SELECT ID, NAME, SALARY  
FROM CUSTOMERS 
WHERE NAME = 'Hardik';

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME     SALARY 
5   Hardik   8500.00

एमएस SQL ​​सर्वर LIKEखंड का उपयोग वाइल्डकार्ड ऑपरेटरों का उपयोग करके समान मूल्यों के मूल्य की तुलना करने के लिए किया जाता है। LIKE ऑपरेटर के साथ संयोजन में उपयोग किए जाने वाले दो वाइल्डकार्ड हैं -

  • प्रतिशत चिन्ह (%)
  • अंडरस्कोर (_)

प्रतिशत चिह्न शून्य, एक या कई वर्णों का प्रतिनिधित्व करता है। अंडरस्कोर एकल संख्या या वर्ण का प्रतिनिधित्व करता है। प्रतीकों का उपयोग संयोजनों में किया जा सकता है।

वाक्य - विन्यास

निम्नलिखित% और _ का मूल सिंटैक्स है।

SELECT *\column-list FROM table_name 
WHERE column LIKE 'XXXX%' 
 
or   

SELECT *\column-list FROM table_name 
WHERE column LIKE '%XXXX%'  

or  

SELECT *\column-list FROM table_name 
WHERE column LIKE 'XXXX_'  

or  

SELECT *\column-list FROM table_name 
WHERE column LIKE '_XXXX'  

or  

SELECT  *\column-list FROM table_name 
WHERE column LIKE '_XXXX_'

आप AND या ऑपरेटर्स का उपयोग करके N की संख्या को जोड़ सकते हैं। XXXX कोई भी संख्यात्मक या स्ट्रिंग मान हो सकता है।

उदाहरण

निम्नलिखित उदाहरण हैं कि '%' और '_' संचालकों के साथ LIKE क्लॉज होने पर WH WH भाग में कितने उदाहरण हैं।

अनु क्रमांक विवरण और विवरण
1

WHERE SALARY LIKE '200%'

200 से शुरू होने वाले किसी भी मान को ढूँढता है

2

WHERE SALARY LIKE '%200%'

किसी भी स्थिति में कोई भी मान प्राप्त करता है

3

WHERE SALARY LIKE '_00%'

किसी भी मान को पाता है जिसमें दूसरे और तीसरे स्थान पर 00 है

4

WHERE SALARY LIKE '2_%_%'

किसी भी मान को जोड़ता है जो 2 से शुरू होता है और लंबाई में कम से कम 3 अक्षर होता है

5

WHERE SALARY LIKE '%2'

किसी भी मान को समाप्त करता है जो 2 के साथ समाप्त होता है

6

WHERE SALARY LIKE '_2%3'

किसी भी मान को प्राप्त करता है, जिसमें दूसरी स्थिति में 2 है और 3 के साथ समाप्त होता है

7

WHERE SALARY LIKE '2___3'

पांच-अंकीय संख्या में किसी भी मान को ढूँढता है जो 2 से शुरू होता है और 3 से समाप्त होता है

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

निम्न आदेश एक उदाहरण है, जो ग्राहक तालिका से सभी रिकॉर्ड प्रदर्शित करेगा जहां सैलरी 200 से शुरू होती है।

SELECT * FROM CUSTOMERS 
WHERE SALARY LIKE '200%';

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID   NAME     AGE     ADDRESS       SALARY 
1    Ramesh   32      Ahmedabad     2000.00 
3    kaushik  23      Kota          2000.00

एमएस SQL ​​सर्वर ORDERएक या अधिक स्तंभों के आधार पर, डेटा को आरोही या अवरोही क्रम में सॉर्ट करने के लिए उपयोग किया जाता है। कुछ डेटाबेस क्रमबद्ध क्वेरी को डिफ़ॉल्ट रूप से आरोही क्रम में रखते हैं।

वाक्य - विन्यास

इसके बाद ORDER BY क्लॉज का मूल सिंटैक्स है।

SELECT column-list  
FROM table_name  
[WHERE condition]  
[ORDER BY column1, column2, .. columnN] [ASC | DESC];

आप ORDER BY क्लॉज में एक से अधिक कॉलम का उपयोग कर सकते हैं। यह सुनिश्चित करने के लिए कि जो भी कॉलम आप सॉर्ट करने के लिए उपयोग कर रहे हैं, वह कॉलम कॉलम-लिस्ट में होना चाहिए।

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

निम्नलिखित आदेश एक उदाहरण है, जो NAME और SALARY द्वारा आरोही क्रम में परिणाम को सॉर्ट करेगा।

SELECT * FROM CUSTOMERS 
   ORDER BY NAME, SALARY

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS           SALARY 
4   Chaitali   25        Mumbai            6500.00 
5   Hardik     27        Bhopal            8500.00 
3   kaushik    23        Kota              2000.00 
2   Khilan     25        Delhi             1500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00 
1   Ramesh     32        Ahmedabad         2000.00

निम्नलिखित आदेश एक उदाहरण है, जो NAME द्वारा अवरोही क्रम में परिणाम को क्रमबद्ध करेगा।

SELECT * FROM CUSTOMERS 
   ORDER BY NAME DESC

उपरोक्त आदेश निम्नलिखित परिणाम का उत्पादन करेगा -

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00
7   Muffy      24        Indore             10000.00  
6   Komal      22        MP                 4500.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00
5   Hardik     27        Bhopal             8500.00
4   Chaitali   25        Mumbai             6500.00

SQL सर्वर GROUP BY समूहों में समान डेटा की व्यवस्था करने के लिए सेलेक्ट स्टेटमेंट के सहयोग से क्लॉज का उपयोग किया जाता है।

ग्रुप BY क्लॉज एक सेलेक्ट स्टेटमेंट में WHERE क्लॉज का अनुसरण करता है और ORDER BY क्लॉज से पहले होता है।

वाक्य - विन्यास

निम्नलिखित समूह BY का मूल सिंटैक्स है। ग्रुप बाय क्लॉज को WHERE क्लॉज की शर्तों का पालन करना चाहिए और यदि कोई प्रयोग किया जाता है तो उसे ORDER BY क्लॉज से पहले होना चाहिए।

SELECT column1, column2 
FROM table_name 
WHERE [ conditions ] 
GROUP BY column1, column2 
ORDER BY column1, column2

उदाहरण

ग्राहक तालिका पर विचार करें निम्नलिखित रिकॉर्ड है -

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Ahmedabad        2000.00 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

यदि आप प्रत्येक ग्राहक पर वेतन की कुल राशि जानना चाहते हैं, तो निम्नलिखित होगा ग्रुप बाय क्वेरी।

SELECT NAME, SUM(SALARY) as [sum of salary] FROM CUSTOMERS 
   GROUP BY NAME;

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

NAME        sum of salary 
Chaitali    6500.00 
Hardik      8500.00 
kaushik     2000.00 
Khilan      1500.00 
Komal       4500.00 
Muffy       10000.00 
Ramesh      2000.00

आइए अब हम निम्नलिखित कस्टमर्स टेबल पर विचार करते हैं जिसमें डुप्लिकेट नामों के साथ निम्नलिखित रिकॉर्ड हैं।

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00 
2   Khilan     25        Delhi             1500.00 
3   kaushik    23        Kota              2000.00 
4   Chaitali   25        Mumbai            6500.00 
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

यदि हम प्रत्येक ग्राहक के वेतन की कुल राशि जानना चाहते हैं, तो ग्रुप बाय क्वेरी होगी।

SELECT NAME, SUM(SALARY) as [sum of salary] FROM CUSTOMERS 
   GROUP BY NAME

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

NAME        sum of salary 
Hardik      8500.00 
kaushik     8500.00 
Komal       4500.00 
Muffy       10000.00 
Ramesh      3500.00

एमएस SQL ​​सर्वर DISTINCT सभी डुप्लिकेट रिकॉर्ड को खत्म करने और केवल विशिष्ट रिकॉर्ड लाने के लिए कीवर्ड का चयन SELECT स्टेटमेंट के साथ किया जाता है।

ऐसी स्थिति हो सकती है जब आपके पास एक तालिका में कई डुप्लिकेट रिकॉर्ड हों। ऐसे रिकॉर्ड प्राप्त करते समय, डुप्लिकेट रिकॉर्ड प्राप्त करने के बजाय केवल अद्वितीय रिकॉर्ड लाने के लिए यह अधिक समझ में आता है।

वाक्य - विन्यास

डुप्लिकेट रिकॉर्ड को खत्म करने के लिए DISTINCT कीवर्ड का मूल सिंटैक्स निम्नलिखित है।

SELECT DISTINCT column1, column2,.....columnN  
FROM table_name 
WHERE [condition]

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

आइए देखें कि निम्न चयन क्वेरी डुप्लिकेट वेतन रिकॉर्ड कैसे देती है।

SELECT SALARY FROM CUSTOMERS 
   ORDER BY SALARY

उपरोक्त आदेश निम्न आउटपुट का उत्पादन करेगा जहां वेतन 2000 दो बार आता है जो मूल तालिका से एक डुप्लिकेट रिकॉर्ड है।

SALARY 
1500.00 
2000.00 
2000.00 
4500.00 
6500.00 
8500.00 
10000.00

आइये अब उपरोक्त चयन क्वेरी के साथ DISTINCT कीवर्ड का उपयोग करें और परिणाम देखें।

SELECT DISTINCT SALARY FROM CUSTOMERS 
   ORDER BY SALARY

उपरोक्त कमांड निम्नलिखित आउटपुट का उत्पादन करता है जहां हमारे पास कोई डुप्लिकेट प्रविष्टि नहीं है।

SALARY 
1500.00 
2000.00 
4500.00 
6500.00 
8500.00 
10000.00

एमएस SQL ​​सर्वर Joinsक्लॉज का उपयोग डेटाबेस में दो या अधिक टेबल से रिकॉर्ड को संयोजित करने के लिए किया जाता है। एक JOIN प्रत्येक के लिए सामान्य मानों का उपयोग करके दो तालिकाओं से फ़ील्ड के संयोजन के लिए एक साधन है।

निम्नलिखित दो तालिकाओं पर विचार करें, (क) ग्राहक तालिका निम्नानुसार है -

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           2000.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              8500.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

(बी) एक और तालिका निम्नानुसार है -

OID  DATE                       CUSTOMER_ID        AMOUNT 
100  2009-10-08 00:00:00.000    3                  1500.00 
101  2009-11-20 00:00:00.000    2                  1560.00 
102  2009-10-08 00:00:00.000    3                  3000.00 
103  2008-05-20 00:00:00.000    4                  2060.00

आइए हम अपने चयन कथन में इन दो तालिकाओं को शामिल करते हैं -

SELECT ID, NAME, AGE, AMOUNT 
   FROM CUSTOMERS, ORDERS 
   WHERE  CUSTOMERS.ID = ORDERS.CUSTOMER_ID 
OR 
SELECT A.ID, A.NAME, A.AGE, B.AMOUNT 
   FROM CUSTOMERS A inner join  ORDERS B on A.ID = B.Customer_ID

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID   NAME      AGE    AMOUNT 
2    Khilan    25     1560.00 
3    kaushik   23     1500.00 
3    kaushik   23     3000.00 
4    Chaitali  25     2060.00

यह ध्यान देने योग्य है कि ज्वाइन WHERE क्लॉज में किया जाता है। तालिकाओं में शामिल होने के लिए कई ऑपरेटरों का उपयोग किया जा सकता है, जैसे =, <,>, <>, <=,> =; =; = BETWEEN, LIKE, और NOT; वे सभी तालिकाओं में शामिल होने के लिए उपयोग किए जा सकते हैं। हालांकि, सबसे आम ऑपरेटर समान प्रतीक है।

MS SQL सर्वर प्रकार शामिल हों -

MS SQL सर्वर में विभिन्न प्रकार के जंक्शन उपलब्ध हैं -

  • INNER JOIN - दोनों टेबलों में मैच होने पर पंक्तियाँ लौटाता है।

  • LEFT JOIN - बाईं मेज से सभी पंक्तियों को लौटाता है, भले ही सही तालिका में कोई मैच न हो।

  • RIGHT JOIN - दाएं टेबल से सभी पंक्तियों को लौटाता है, भले ही बाईं तालिका में कोई मेल न हो।

  • FULL JOIN - तालिकाओं में से एक में एक मैच होने पर पंक्तियाँ लौटाता है।

  • SELF JOIN - इसका उपयोग किसी तालिका को स्वयं में शामिल करने के लिए किया जाता है जैसे कि तालिका दो तालिकाएं थीं, अस्थायी रूप से एमएस SQL ​​सर्वर स्टेटमेंट में कम से कम एक तालिका का नाम बदलकर।

  • CARTESIAN JOIN - दो या अधिक सम्मिलित तालिकाओं से अभिलेखों के सेट का कार्टेशियन उत्पाद लौटाता है।

sub-query या Inner query या Nested queryएक अन्य SQL सर्वर क्वेरी के भीतर एक क्वेरी है और WHERE क्लॉज के भीतर एम्बेडेड है। डेटा को वापस लाने के लिए एक उप क्वेरी का उपयोग किया जाता है जो डेटा को पुनः प्राप्त करने के लिए प्रतिबंधित करने के लिए एक शर्त के रूप में मुख्य क्वेरी में उपयोग किया जाएगा।

उप प्रश्नों को SELECT, INSERT, UPDATE, और DELETE स्टेटमेंट्स के साथ ऑपरेटर्स जैसे =, <,>,> =, <=, IN, BETWEEN, आदि के साथ प्रयोग किया जा सकता है।

कुछ नियम हैं जो उप प्रश्नों का पालन करना चाहिए -

  • आपको कोष्ठक में एक उपशम को जोड़ना होगा।

  • एक उप-वर्ग में एक सेलेक्ट क्लॉज और एक FROM क्लॉज शामिल होना चाहिए।

  • एक उपश्रेणी में वैकल्पिक WHERE, GROUP BY और HAVING खंड शामिल हो सकते हैं।

  • एक उपकुंजी में COMPUTE या BROWSE क्लॉस शामिल नहीं हो सकते।

  • आप ORDER BY क्लॉज़ को केवल तभी शामिल कर सकते हैं जब कोई TOP क्लॉज़ शामिल हो।

  • आप 32 स्तरों तक उप प्रश्नों को घोंसला बना सकते हैं।

चयन कथन के साथ उपश्रेणियाँ

वाक्य - विन्यास

सबक्वेरी का उपयोग अक्सर सेलेक्ट स्टेटमेंट के साथ किया जाता है। निम्नलिखित मूल सिंटैक्स है।

SELECT column_name [, column_name ] 
FROM   table1 [, table2 ] 
WHERE  column_name OPERATOR 
   (SELECT column_name [, column_name ] 
   FROM table1 [, table2 ] 
   [WHERE])

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

हमें सेलेक्ट स्टेटमेंट के साथ निम्नलिखित सबक्विरी लागू करते हैं।

SELECT *  
   FROM CUSTOMERS
   WHERE ID IN (SELECT ID FROM CUSTOMERS WHERE SALARY > 4500)

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS          SALARY 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
7   Muffy      24        Indore           10000.00

INSERT वक्तव्य के साथ उपश्रेणियाँ

उप प्रश्नों का उपयोग INSERT कथनों के साथ भी किया जा सकता है। INSERT विवरण उपकुंजी से लौटाए गए डेटा का उपयोग किसी अन्य तालिका में सम्मिलित करने के लिए करता है। उपकुंजी में चयनित डेटा को किसी भी चरित्र, दिनांक, या संख्या कार्यों के साथ संशोधित किया जा सकता है।

वाक्य - विन्यास

निम्नलिखित मूल सिंटैक्स है।

INSERT INTO table_name [ (column1 [, column2 ]) ] 
   SELECT [ *|column1 [, column2 ] 
   FROM table1 [, table2 ] 
   [ WHERE VALUE OPERATOR ]

उदाहरण

एक तालिका CUSTOMERS_BKP पर विचार करें जैसे CUSTOMERS तालिका के समान संरचना। CUSTOMERS_BKP में पूरा कस्टमर टेबल कॉपी करने का सिंटैक्स निम्नलिखित है।

INSERT INTO CUSTOMERS_BKP 
   SELECT * FROM CUSTOMERS  
   WHERE ID IN (SELECT ID FROM CUSTOMERS)

अद्यतन विवरण के साथ उपश्रेणियाँ

उपखंड का उपयोग अद्यतन कथन के साथ किया जा सकता है। अद्यतन के साथ एक तालिका में एकल या एकाधिक स्तंभ अद्यतन किया जा सकता है जब अद्यतन कथन के साथ।

वाक्य - विन्यास

निम्नलिखित मूल सिंटैक्स है।

UPDATE table 
SET column_name = new_value 
[ WHERE OPERATOR [ VALUE ] 
   (SELECT COLUMN_NAME 
   FROM TABLE_NAME) 
   [ WHERE) ]

उदाहरण

मान लें कि हमारे पास CUSTOMERS_BKP तालिका उपलब्ध है जो CUSTOMERS तालिका का बैकअप है।

उन सभी ग्राहकों के लिए, जिनकी AGE 27 से अधिक या उससे अधिक है, के लिए CUSTOMERS तालिका में सैलेरी को 0.25 गुना करके कमांड उदाहरण का अद्यतन करता है।

UPDATE CUSTOMERS 
   SET SALARY = SALARY * 0.25 
   WHERE AGE IN (SELECT AGE FROM CUSTOMERS_BKP WHERE AGE >= 27 )

यह दो पंक्तियों को प्रभावित करेगा और अंत में CUSTOMERS तालिका में निम्नलिखित रिकॉर्ड होंगे।

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           500.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              2125.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

DELETE कथन के साथ उपश्रेणियाँ

उपखंड का उपयोग DELETE कथन के साथ संयोजन के रूप में किया जा सकता है, जैसा कि ऊपर उल्लिखित किसी भी अन्य कथन के साथ किया जा सकता है।

वाक्य - विन्यास

निम्नलिखित मूल सिंटैक्स है।

DELETE FROM TABLE_NAME 
[ WHERE OPERATOR [ VALUE ] 
   (SELECT COLUMN_NAME 
   FROM TABLE_NAME) 
   [ WHERE) ]

उदाहरण

मान लें कि हमारे पास CUSTOMERS_BKP तालिका उपलब्ध है जो CUSTOMERS तालिका का बैकअप है।

आदेश के बाद का उदाहरण उन सभी ग्राहकों के लिए ग्राहक तालिका से रिकॉर्ड हटा देता है, जिनका AGE 27 से अधिक या उसके बराबर है।

DELETE FROM CUSTOMERS 
   WHERE AGE IN (SELECT AGE FROM CUSTOMERS_BKP WHERE AGE >=27 )

यह दो पंक्तियों को प्रभावित करेगा और अंत में CUSTOMERS तालिका में निम्नलिखित रिकॉर्ड होंगे।

ID  NAME       AGE       ADDRESS          SALARY 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00  
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

एमएस SQL ​​सर्वर Stored procedure डेटाबेस में समान संग्रहीत करके बार-बार कोड लिखने के लिए समय बचाने के लिए उपयोग किया जाता है और मापदंडों को पारित करके आवश्यक आउटपुट भी प्राप्त करता है।

वाक्य - विन्यास

निम्नलिखित संग्रहित प्रक्रिया निर्माण का मूल सिंटैक्स है।

Create procedure <procedure_Name> 
As 
Begin 
<SQL Statement> 
End 
Go

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

निम्न आदेश एक उदाहरण है जो टेस्टडब डेटाबेस में कस्टमर्स टेबल से सभी रिकॉर्ड प्राप्त करेगा।

CREATE PROCEDURE SelectCustomerstabledata 
AS 
SELECT * FROM Testdb.Customers 
GO

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00 
2   Khilan     25        Delhi             1500.00 
3   kaushik    23        Kota              2000.00 
4   Chaitali   25        Mumbai            6500.00 
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

transactionएक डेटाबेस के खिलाफ किया जाता है कि काम की एक इकाई है। लेन-देन एक तार्किक क्रम में पूरी की जाने वाली इकाइयाँ या अनुक्रम हैं, चाहे वह किसी उपयोगकर्ता द्वारा मैन्युअल रूप से या किसी प्रकार के डेटाबेस प्रोग्राम द्वारा स्वचालित रूप से हो।

लेन-देन डेटाबेस में एक या एक से अधिक परिवर्तनों का प्रसार है। उदाहरण के लिए, यदि आप कोई रिकॉर्ड बना रहे हैं या रिकॉर्ड अपडेट कर रहे हैं या टेबल से कोई रिकॉर्ड हटा रहे हैं, तो आप टेबल पर लेनदेन कर रहे हैं। डेटा अखंडता सुनिश्चित करने और डेटाबेस त्रुटियों को संभालने के लिए लेनदेन को नियंत्रित करना महत्वपूर्ण है।

व्यावहारिक रूप से, आप एक समूह में कई एसक्यूएल प्रश्नों को क्लब करेंगे और आप लेनदेन के एक हिस्से के रूप में उन सभी को एक साथ निष्पादित करेंगे।

लेन-देन के गुण

लेन-देन में निम्नलिखित चार मानक गुण होते हैं, जिन्हें आमतौर पर संक्षिप्त ACID द्वारा संदर्भित किया जाता है -

  • Atomicity- यह सुनिश्चित करता है कि कार्य इकाई के भीतर सभी संचालन सफलतापूर्वक पूरा हो गए हैं; अन्यथा, लेनदेन को विफलता के बिंदु पर निरस्त कर दिया जाता है, और पिछले ऑपरेशनों को उनके पूर्व राज्य में वापस ले जाया जाता है।

  • Consistency - सुनिश्चित करता है कि डेटाबेस सफलतापूर्वक किए गए लेनदेन पर स्थिति को ठीक से बदल देता है।

  • Isolation - स्वतंत्र रूप से और एक दूसरे के लिए पारदर्शी संचालित करने के लिए लेनदेन को सक्षम करता है।

  • Durability - सुनिश्चित करता है कि प्रतिबद्ध लेनदेन का परिणाम या प्रभाव एक सिस्टम विफलता के मामले में बना रहता है।

लेन-देन नियंत्रण

लेनदेन को नियंत्रित करने के लिए उपयोग किए जाने वाले आदेश निम्नलिखित हैं -

  • COMMIT - परिवर्तनों को बचाने के लिए।

  • ROLLBACK - परिवर्तन वापस करने के लिए।

  • SAVEPOINT - लेन-देन के समूहों के भीतर अंक बनाता है जिसमें रोलबैक के लिए।

  • SET TRANSACTION - एक लेनदेन पर एक नाम रखता है।

लेन-देन नियंत्रण आदेश केवल डीएमएल कमांड INSERT, UPDATE और DELETE के साथ ही उपयोग किए जाते हैं। इनका उपयोग तालिकाओं को बनाने या उन्हें गिराने के दौरान नहीं किया जा सकता क्योंकि ये ऑपरेशन डेटाबेस में स्वचालित रूप से प्रतिबद्ध होते हैं।

MS SQL सर्वर में ट्रांजेक्शनल कंट्रोल कमांड्स का उपयोग करने के लिए, हमें 'ट्रान्स स्टार्ट' के साथ लेन-देन शुरू करना होगा या ट्रांजैक्शन कमांड शुरू करना होगा अन्यथा ये कमांड काम नहीं करेंगे।

COMMIT कमांड

COMMIT कमांड एक ट्रांसेक्शनल कमांड है जिसका उपयोग डेटाबेस में ट्रांजेक्शन के लिए किए गए परिवर्तनों को सहेजने के लिए किया जाता है। यह कमांड अंतिम COMMIT या रोलबैक कमांड के बाद से डेटाबेस के लिए सभी लेनदेन बचाता है।

वाक्य - विन्यास

निम्नलिखित COMMIT कमांड के लिए सिंटैक्स है।

COMMIT;

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00 
2   Khilan     25        Delhi             1500.00 
3   kaushik    23        Kota              2000.00 
4   Chaitali   25        Mumbai            6500.00 
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

आदेश उदाहरण के बाद उम्र = 25 होने वाली तालिका से रिकॉर्ड हटाए जाएंगे और फिर डेटाबेस में बदलावों की पुष्टि करेंगे।

Begin Tran 
DELETE FROM CUSTOMERS 
   WHERE AGE = 25 
COMMIT

परिणामस्वरूप, तालिका से दो पंक्तियों को हटा दिया जाएगा और SELECT कथन निम्न आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00
3   kaushik    23        Kota              2000.00
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

रोलबैक कमांड

रोलबैक कमांड लेनदेन को पूर्ववत करने के लिए उपयोग किया जाने वाला ट्रांसेक्शनल कमांड है जिसे पहले से डेटाबेस में सहेजा नहीं गया है। यह आदेश केवल पिछले COMMIT या ROLLBACK आदेश जारी होने के बाद लेनदेन को पूर्ववत करने के लिए उपयोग किया जा सकता है।

वाक्य - विन्यास

ROLLBACK कमांड के लिए सिंटैक्स निम्नलिखित है।

ROLLBACK

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

आदेश उदाहरण के बाद, तालिका की आयु = 25 से रिकॉर्ड हटा दिया जाएगा और फिर डेटाबेस में परिवर्तन को रोकें।

Begin Tran 
DELETE FROM CUSTOMERS 
   WHERE AGE = 25; 
ROLLBACK

परिणामस्वरूप, डिलीट ऑपरेशन टेबल पर असर नहीं करेगा और सेलेक्ट स्टेटमेंट निम्न परिणाम देगा।

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Ahmedabad        2000.00 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

SAVEPOINT कमान

SAVEPOINT एक लेनदेन में एक बिंदु है जब आप पूरे लेनदेन को वापस किए बिना लेनदेन को एक निश्चित बिंदु पर वापस रोल कर सकते हैं।

वाक्य - विन्यास

SAVEPOINT कमांड के लिए सिंटैक्स निम्नलिखित है।

SAVE TRANSACTION SAVEPOINT_NAME

यह आदेश केवल लेन-देन बयानों के बीच एक बचत के निर्माण में कार्य करता है। रोलबैक आदेश का उपयोग लेनदेन के एक समूह को पूर्ववत करने के लिए किया जाता है।

SAVEPOINT पर वापस जाने के लिए सिंटैक्स निम्नलिखित है।

ROLLBACK TO SAVEPOINT_NAME

निम्नलिखित उदाहरण में, हम ग्राहक तालिका से तीन अलग-अलग रिकॉर्ड हटा देंगे। हमें प्रत्येक डिलीट से पहले एक SAVEPOINT बनाना होगा, ताकि हम किसी भी समय किसी भी SAVEPOINT को अपने मूल राज्य में उचित डेटा वापस करने के लिए लोड कर सकें।

उदाहरण

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें -

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Ahmedabad        2000.00 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

संचालन की श्रृंखला निम्नलिखित हैं -

Begin Tran 
SAVE Transaction SP1 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 1  
1 row deleted. 
SAVE Transaction SP2 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 2 
1 row deleted.
SAVE Transaction SP3 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 3 
1 row deleted.

तीन विलोपन हो चुके हैं, हालाँकि, हमने अपना विचार बदल दिया है और उस SAVEPOINT को ROLLBACK करने का निर्णय लिया है जिसे हमने SP2 के रूप में पहचाना था। क्योंकि SP2 को पहले हटाने के बाद बनाया गया था, अंतिम दो हटाए गए पूर्ववत हैं -

ROLLBACK Transaction SP2 
Rollback complete.

ध्यान दें कि जब हम SP2 में वापस आए थे तब से केवल पहला विलोपन हुआ था।

SELECT * FROM CUSTOMERS

6 पंक्तियों का चयन किया।

ID  NAME       AGE       ADDRESS          SALARY 
2   Khilan     25        Delhi        1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

सेट परिवहन आदेश

डेटाबेस ट्रांजेक्शन शुरू करने के लिए SET TRANSACTION कमांड का उपयोग किया जा सकता है। इस आदेश का उपयोग लेनदेन के लिए विशेषताओं को निर्दिष्ट करने के लिए किया जाता है।

वाक्य - विन्यास

SET ट्रांज़ेक्शन के लिए सिंटैक्स है।

SET TRANSACTION ISOLATION LEVEL <Isolationlevel_name>

Indexesडेटाबेस खोज इंजन डेटा पुनर्प्राप्ति को गति देने के लिए उपयोग कर सकते हैं विशेष लुकअप टेबल हैं। सीधे शब्दों में कहें, एindexएक तालिका में डेटा के लिए एक सूचक है। एक डेटाबेस में एक इंडेक्स एक किताब के अंत में एक इंडेक्स के समान है।

उदाहरण के लिए, यदि आप किसी विषय पर चर्चा करने वाली पुस्तक के सभी पृष्ठों को संदर्भित करना चाहते हैं, तो आप पहले सूचकांक का उल्लेख करते हैं, जो सभी विषयों को वर्णानुक्रम में सूचीबद्ध करता है और फिर एक या अधिक विशिष्ट पृष्ठ संख्याओं के लिए संदर्भित किया जाता है।

एक इंडेक्स सेलेक्टेड क्वेश्चन और जहां क्लॉस होता है, को गति देने में मदद करता है, लेकिन यह डेटा इनपुट को धीमा कर देता है, जिसमें अपडेट और इनसेट स्टेटमेंट होते हैं। इंडेक्स डेटा पर कोई प्रभाव नहीं बनाया या गिराया जा सकता है।

एक इंडेक्स बनाने में क्रिएट इंडेक्स स्टेटमेंट शामिल होता है, जो आपको इंडेक्स नाम देने की अनुमति देता है, तालिका को निर्दिष्ट करने के लिए और कौन सा कॉलम या कॉलम इंडेक्स करने के लिए, और यह इंगित करने के लिए कि इंडेक्स आरोही या अवरोही क्रम में है या नहीं।

सूचकांक अद्वितीय भी हो सकता है, UNIQUE बाधा के समान, इसमें सूचकांक कॉलम में डुप्लिकेट प्रविष्टियों या स्तंभों के संयोजन को रोकता है, जिस पर एक सूचकांक है।

सृजन सूचकांक कमान

निम्नलिखित क्रिएट इंडेक्स का मूल सिंटैक्स है।

वाक्य - विन्यास

CREATE INDEX index_name ON table_name

सिंगल-कॉलम इंडेक्स

एकल-स्तंभ अनुक्रमणिका वह है जो केवल एक तालिका स्तंभ के आधार पर बनाई गई है। निम्नलिखित मूल सिंटैक्स है।

वाक्य - विन्यास

CREATE INDEX index_name 
ON table_name (column_name)

उदाहरण

CREATE INDEX singlecolumnindex 
ON customers (ID)

अनोखा सूचकांक

यूनीक इंडेक्स का उपयोग न केवल प्रदर्शन के लिए किया जाता है, बल्कि डेटा अखंडता के लिए भी किया जाता है। एक अद्वितीय सूचकांक किसी भी डुप्लिकेट मानों को तालिका में सम्मिलित करने की अनुमति नहीं देता है। निम्नलिखित मूल सिंटैक्स है।

वाक्य - विन्यास

CREATE UNIQUE INDEX index_name 
on table_name (column_name)

उदाहरण

CREATE UNIQUE INDEX uniqueindex 
on customers (NAME)

समग्र सूचकांक

एक संयुक्त सूचकांक एक तालिका के दो या अधिक स्तंभों पर एक सूचकांक है। निम्नलिखित मूल सिंटैक्स है।

वाक्य - विन्यास

CREATE INDEX index_name on table_name (column1, column2)

उदाहरण

CREATE INDEX compositeindex 
on customers (NAME, ID)

चाहे सिंगल-कॉलम इंडेक्स या कंपोजिट इंडेक्स बनाएं, कॉलम (एस) को ध्यान में रखें जो आप क्वेरी के WHERE क्लॉज में फिल्टर शर्तों के रूप में बहुत बार उपयोग कर सकते हैं।

क्या केवल एक कॉलम का उपयोग किया जाना चाहिए, एकल-कॉलम इंडेक्स का विकल्प होना चाहिए। क्या दो या दो से अधिक कॉलम होने चाहिए, जिन्हें अक्सर फिल्टर के रूप में WHERE क्लॉज में उपयोग किया जाता है, कम्पोजिट इंडेक्स सबसे अच्छा विकल्प होगा।

निहित सूचकांक

इंप्लिकेट इंडेक्स इंडेक्स होते हैं जो किसी ऑब्जेक्ट के बनने पर डेटाबेस सर्वर द्वारा स्वचालित रूप से बनाए जाते हैं। प्राथमिक कुंजी बाधाओं और अद्वितीय बाधाओं के लिए अनुक्रमणिका स्वचालित रूप से बनाई जाती हैं।

DROP INDEX कमांड

MS SQL SERVER DROP कमांड का उपयोग करके एक इंडेक्स को छोड़ा जा सकता है। इंडेक्स ड्रॉप करते समय ध्यान रखा जाना चाहिए क्योंकि प्रदर्शन धीमा या बेहतर हो सकता है।

वाक्य - विन्यास

निम्नलिखित मूल सिंटैक्स है।

DROP INDEX tablename.index_name

सूचकांक से कब बचें?

हालाँकि, अनुक्रमित डेटाबेस के प्रदर्शन को बढ़ाने के उद्देश्य से होते हैं, लेकिन कई बार ऐसे समय होते हैं जब उन्हें टाला जाना चाहिए। सूचकांक के उपयोग पर पुनर्विचार किया जाना चाहिए, जब निम्नलिखित दिशा-निर्देश इंगित करते हैं -

  • इंडेक्स का उपयोग छोटी तालिकाओं पर नहीं किया जाना चाहिए।

  • जिन टेबलों में बार-बार, बड़े बैच अपडेट या इंसर्ट ऑपरेशन होते हैं उन्हें इंडेक्स नहीं किया जाना चाहिए।

  • अनुक्रमणिकाओं का उपयोग उन स्तंभों पर नहीं किया जाना चाहिए जिनमें अधिक संख्या में NULL मान हैं।

  • जिन कॉलमों में अक्सर हेरफेर किया जाता है, उन्हें अनुक्रमित नहीं किया जाना चाहिए।

MS SQL सर्वर में स्ट्रिंग या न्यूमेरिक डेटा पर प्रोसेसिंग करने के लिए कई अंतर्निहित कार्य होते हैं। निम्नलिखित सभी उपयोगी SQL अंतर्निहित कार्यों की सूची है -

  • SQL Server COUNT Function - SQL सर्वर COUNT सकल फ़ंक्शन का उपयोग डेटाबेस तालिका में पंक्तियों की संख्या की गणना करने के लिए किया जाता है।

  • SQL Server MAX Function - SQL सर्वर MAX समुच्चय फ़ंक्शन एक निश्चित कॉलम के लिए उच्चतम (अधिकतम) मान का चयन करने की अनुमति देता है।

  • SQL Server MIN Function - SQL सर्वर MIN कुल फ़ंक्शन एक निश्चित कॉलम के लिए न्यूनतम (न्यूनतम) मान का चयन करने की अनुमति देता है।

  • SQL Server AVG Function - SQL सर्वर AVG कुल फ़ंक्शन कुछ तालिका स्तंभ के लिए औसत मान का चयन करता है।

  • SQL Server SUM Function - SQL सर्वर SUM कुल फ़ंक्शन एक संख्यात्मक स्तंभ के लिए कुल का चयन करने की अनुमति देता है।

  • SQL Server SQRT Function - इसका उपयोग किसी दिए गए नंबर का वर्गमूल उत्पन्न करने के लिए किया जाता है।

  • SQL Server RAND Function - इसका उपयोग SQL कमांड का उपयोग करके एक यादृच्छिक संख्या उत्पन्न करने के लिए किया जाता है।

  • SQL Server CONCAT Function - यह एक पैरामीटर के लिए कई मापदंडों को समाप्‍त करने के लिए उपयोग किया जाता है।

  • SQL Server Numeric Functions - SQL में संख्याओं में हेरफेर करने के लिए आवश्यक SQL फ़ंक्शन की पूरी सूची।

  • SQL Server String Functions - एसक्यूएल में स्ट्रिंग में हेरफेर करने के लिए आवश्यक एसक्यूएल कार्यों की पूरी सूची।

MS SQL सर्वर स्ट्रिंग फ़ंक्शन स्ट्रिंग मान पर लागू किया जा सकता है या स्ट्रिंग मान या संख्यात्मक डेटा लौटाएगा।

उदाहरण के साथ स्ट्रिंग फ़ंक्शन की सूची निम्न है।

ASCII ()

Ascii कोड मान एक वर्ण अभिव्यक्ति के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्न क्वेरी किसी दिए गए वर्ण का Ascii कोड मान देगा।

Select ASCII ('word')

CHAR ()

कैरेक्टर दिए गए Ascii कोड या पूर्णांक के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी किसी पूर्णांक के लिए वर्ण देगा।

Select CHAR(97)

NCHAR ()

यूनिकोड वर्ण किसी दिए गए पूर्णांक के आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न किसी दिए गए पूर्णांक के लिए यूनिकोड वर्ण देगा।

Select NCHAR(300)

CHARINDEX ()

दी गई खोज अभिव्यक्ति के लिए प्रारंभिक स्थिति एक दिए गए स्ट्रिंग अभिव्यक्ति में आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित प्रश्न दिए गए स्ट्रिंग अभिव्यक्ति 'किंग' के लिए 'जी' चरित्र की शुरुआती स्थिति देगा।

Select CHARINDEX('G', 'KING')

बाएं()

दिए गए स्ट्रिंग का बायाँ हिस्सा तब तक निर्दिष्ट रहेगा जब तक कि वर्णों की संख्या किसी दिए गए स्ट्रिंग के आउटपुट के रूप में नहीं आ जाएगी।

उदाहरण

निम्नलिखित प्रश्न 'वर्ल' स्ट्रिंग को दिए गए स्ट्रिंग 'वर्ल्ड' के लिए वर्णों की संख्या 4 बताएंगे।

Select LEFT('WORLD', 4)

सही()

दिए गए स्ट्रिंग का दाहिना भाग तब तक निर्दिष्ट होता है जब तक कि वर्णों की संख्या किसी दिए गए स्ट्रिंग के आउटपुट के रूप में नहीं आ जाएगी।

उदाहरण

निम्नलिखित क्वेरी 'DIA' स्ट्रिंग को दिए गए स्ट्रिंग 'INDIA' के लिए वर्णों की संख्या 3 बताएगी।

Select RIGHT('INDIA', 3)

सबस्ट्रिंग ()

स्टार्ट पोजीशन वैल्यू और लेंथ वैल्यू के आधार पर एक स्ट्रिंग का हिस्सा किसी दिए गए स्ट्रिंग के आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न 'फर्म', 'डीआईए', 'आईएनजी' तार देंगे जैसा कि हमने उल्लेख किया है (1,3), (3,3) और (2,3) क्रमशः और लंबाई मान दिए गए तार 'वर्ल्ड' के लिए। , 'भारत' और 'किंग'।

Select SUBSTRING ('WORLD', 1,3) 
Select SUBSTRING ('INDIA', 3,3) 
Select SUBSTRING ('KING', 2,3)

LEN ()

पात्रों की संख्या एक दिए गए स्ट्रिंग अभिव्यक्ति के लिए आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित प्रश्न 'HELLO' स्ट्रिंग अभिव्यक्ति के लिए 5 देगा।

Select LEN('HELLO')

कम ()

लोअरकेस स्ट्रिंग एक दिए गए स्ट्रिंग डेटा के आउटपुट के रूप में आएगा।

उदाहरण

निम्न प्रश्न 'SQLServer' वर्ण डेटा के लिए 'sqlserver' देगा।

Select LOWER('SQLServer')

ऊपरी ()

अपरकेस स्ट्रिंग एक दिए गए स्ट्रिंग डेटा के आउटपुट के रूप में आएगा।

उदाहरण

निम्न प्रश्न 'SqlServer' वर्ण डेटा के लिए 'SQLSERVER' देगा।

Select UPPER('SqlServer')

LTRIM ()

स्ट्रिंग की अभिव्यक्ति प्रमुख रिक्त स्थान को हटाने के बाद दिए गए स्ट्रिंग डेटा के लिए आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित क्वेरी 'वर्ल्ड' चरित्र डेटा के लिए 'वर्ल्ड' देगी।

Select LTRIM('   WORLD')

RTRIM ()

स्ट्रिंग एक्सप्रेशंस रिक्त स्थान को हटाने के बाद दिए गए स्ट्रिंग डेटा के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी 'INDIA' वर्ण डेटा के लिए 'INDIA' देगी।

Select RTRIM('INDIA   ')

बदलने के()

निर्दिष्ट वर्ण के साथ निर्दिष्ट वर्ण की सभी आवृत्तियों को प्रतिस्थापित करने के बाद दिए गए स्ट्रिंग डेटा के लिए स्ट्रिंग अभिव्यक्ति आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित क्वेरी 'INDIA' स्ट्रिंग डेटा के लिए 'KNDKA' स्ट्रिंग देगी।

Select REPLACE('INDIA', 'I', 'K')

दोहराने ()

बार-बार निर्दिष्ट संख्या के साथ दिए गए स्ट्रिंग डेटा के लिए रिपीट स्ट्रिंग एक्सप्रेशन आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न 'वर्ल्डवाइड' स्ट्रिंग को 'वर्ल्ड' स्ट्रिंग डेटा देगा।

Select REPLICATE('WORLD', 2)

उलटना()

रिवर्स स्ट्रिंग एक्सप्रेशन किसी दिए गए स्ट्रिंग डेटा के आउटपुट के रूप में आएगा।

उदाहरण

निम्न क्वेरी 'DLROW' स्ट्रिंग को 'वर्ल्ड' स्ट्रिंग डेटा के लिए देगी।

Select REVERSE('WORLD')

Soundex ()

दिए गए तार की समानता का मूल्यांकन करने के लिए चार-वर्ण (SOUNDEX) कोड लौटाता है।

उदाहरण

निम्न प्रश्न 'स्मिथ', 'स्माइथ' स्ट्रिंग्स के लिए 'S530' देगा।

Select SOUNDEX('Smith'), SOUNDEX('Smyth')

अंतर()

पूर्णांक मूल्य दिए गए दो भावों के आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न 'स्मिथ', 'स्माइथ' अभिव्यक्तियों के लिए 4 देगा।

Select Difference('Smith','Smyth')

Note - यदि आउटपुट मान 0 है, तो यह कमजोर या कोई समानता नहीं देता है कि 2 भाव दें।

अंतरिक्ष ()

स्ट्रिंग स्पेस की निर्दिष्ट संख्या के साथ आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित प्रश्न 'I LOVE INDIA' देगा।

Select 'I'+space(1)+'LOVE'+space(1)+'INDIA'

STUFF ()

स्ट्रिंग की अभिव्यक्ति निर्दिष्ट चरित्र के साथ निर्दिष्ट लंबाई तक प्रारंभिक चरित्र से बदलने के बाद दिए गए स्ट्रिंग डेटा के लिए आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित प्रश्न 'ABCDEFGH' स्ट्रिंग डेटा के लिए 'AIJKFGH' स्ट्रिंग क्रमशः दिए गए वर्ण और लंबाई के अनुसार क्रमशः 2 और 4 और निर्दिष्ट लक्ष्य स्ट्रिंग के रूप में 'IJK' देगा।

Select STUFF('ABCDEFGH', 2,4,'IJK')

एसटीआर ()

कैरेक्टर डेटा दिए गए न्यूमेरिक डेटा के आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न दिए गए 187.369 के लिए 187.37 निर्दिष्ट लंबाई के आधार पर 6 और दशमलव 2 के रूप में देगा।

Select STR(187.369,6,2)

यूनिकोड ()

पूर्णांक अभिव्यक्ति के पहले वर्ण के लिए आउटपुट के रूप में आयेगा।

उदाहरण

निम्नलिखित क्वेरी 'RAMA' अभिव्यक्ति के लिए 82 देगी।

Select UNICODE('RAMA')

QUOTENAME ()

दिया गया स्ट्रिंग निर्दिष्ट सीमांकक के साथ आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी दी गई 'RAMA' स्ट्रिंग के लिए "RAMA" देगी क्योंकि हमने सीमांकक के रूप में दोहरा उद्धरण निर्दिष्ट किया था।

Select QUOTENAME('RAMA','"')

PATINDEX ()

दी गई अभिव्यक्ति से पहली घटना की स्थिति के रूप में हम निर्दिष्ट 'मैं' स्थिति की आवश्यकता है।

उदाहरण

निम्नलिखित प्रश्न 'भारत' के लिए 1 देगा।

Select PATINDEX('I%','INDIA')

प्रारूप ()

दिए गए अभिव्यक्ति निर्दिष्ट प्रारूप के साथ आउटपुट के रूप में आएंगे।

उदाहरण

निम्नलिखित क्वेरी 'डी' के साथ निर्दिष्ट प्रारूप के अनुसार गेटडेट फ़ंक्शन के लिए 'सोमवार, 16 नवंबर, 2015' को दे देगी।

SELECT FORMAT ( getdate(), 'D')

Concat ()

दिए गए पैरामीटर मानों को समाप्‍त करने के बाद एकल स्ट्रिंग आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित प्रश्न दिए गए मापदंडों के लिए 'ए, बी, सी' देगा।

Select CONCAT('A',',','B',',','C')

MS SQL सर्वर में दिनांक कार्यों की सूची निम्नलिखित है।

तारीख लें()

यह समय के साथ-साथ वर्तमान तिथि लौटाएगा।

वाक्य - विन्यास

उपरोक्त फ़ंक्शन के लिए सिंटैक्स -

GETDATE()

उदाहरण

निम्न क्वेरी MS SQL सर्वर में समय के साथ-साथ वर्तमान दिनांक को लौटा देगी।

Select getdate() as currentdatetime

DatePart ()

यह तारीख या समय का हिस्सा लौटाएगा।

वाक्य - विन्यास

उपरोक्त फ़ंक्शन के लिए सिंटैक्स -

DATEPART(datepart, datecolumnname)

उदाहरण

Example 1 - निम्नलिखित क्वेरी एमएस SQL ​​सर्वर में वर्तमान तिथि के हिस्से को वापस कर देगी।

Select datepart(day, getdate()) as currentdate

Example 2 - निम्नलिखित क्वेरी एमएस SQL ​​सर्वर में वर्तमान महीने के हिस्से को वापस कर देगी।

Select datepart(month, getdate()) as currentmonth

DATEADD ()

यह दिनांक और समय अंतराल को जोड़कर या घटाकर तिथि और समय प्रदर्शित करेगा।

वाक्य - विन्यास

उपरोक्त फ़ंक्शन के लिए सिंटैक्स -

DATEADD(datepart, number, datecolumnname)

उदाहरण

निम्न क्वेरी MS SQL सर्वर में वर्तमान दिनांक और समय से 10 दिनों की तारीख और समय के बाद वापस आ जाएगी।

Select dateadd(day, 10, getdate()) as after10daysdatetimefromcurrentdatetime

DateDiff ()

यह दो तिथियों के बीच की तिथि और समय प्रदर्शित करेगा।

वाक्य - विन्यास

उपरोक्त फ़ंक्शन के लिए सिंटैक्स -

DATEDIFF(datepart, startdate, enddate)

उदाहरण

निम्न क्वेरी एमएस SQL ​​सर्वर में 2015-11-16 और 2015-11-11 के बीच के घंटों का अंतर लौटाएगी।

Select datediff(hour, 2015-11-16, 2015-11-11) as 
differencehoursbetween20151116and20151111

CONVERT ()

यह विभिन्न स्वरूपों में दिनांक और समय प्रदर्शित करेगा।

वाक्य - विन्यास

उपरोक्त फ़ंक्शन के लिए सिंटैक्स -

CONVERT(datatype, expression, style)

उदाहरण

निम्नलिखित क्वेरीज़ MS SQL सर्वर में भिन्न स्वरूप में दिनांक और समय लौटाएगी।

SELECT CONVERT(VARCHAR(19),GETDATE()) 
SELECT CONVERT(VARCHAR(10),GETDATE(),10) 
SELECT CONVERT(VARCHAR(10),GETDATE(),110)

MS SQL सर्वर संख्यात्मक कार्य संख्यात्मक डेटा पर लागू किया जा सकता है और संख्यात्मक डेटा लौटाएगा।

उदाहरण के साथ न्यूमेरिक कार्यों की सूची निम्नलिखित है।

ABS ()

पूर्णांक संख्यात्मक अभिव्यक्ति के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्न क्वेरी निरपेक्ष मान देगी।

Select ABS(-22)

ACOS ()

आर्क कॉज़िन मूल्य निर्दिष्ट संख्यात्मक अभिव्यक्ति के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्न क्वेरी चाप को 0 का कोज्या मान देगी।

Select ACOS(0)

जैसे की()

आर्क साइन मूल्य निर्दिष्ट संख्यात्मक अभिव्यक्ति के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी आर्क साइन 0 का मान देगी।

Select ASIN(0)

एक भूरा()

आर्क स्पर्शरेखा मूल्य निर्दिष्ट संख्यात्मक अभिव्यक्ति के लिए आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी आर्क आर्क को 0 का मान देगी।

Select ATAN(0)

ATN2 ()

सभी चार चतुर्थांशों में आर्क स्पर्शरेखा निर्दिष्ट संख्यात्मक अभिव्यक्ति के लिए आउटपुट के रूप में आएगी।

उदाहरण

निम्नलिखित क्वेरी 0 के सभी चार क्वाड्रंट में आर्क स्पर्शरेखा मूल्य देगी।

Select ATN2(0, -1)

निम्नलिखित रिकॉर्ड वाले ग्राहक तालिका पर विचार करें।

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           2000.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              8500.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

के बीच()

यदि दिए गए दो भावों के बीच मान मौजूद हैं, तो वे आउटपुट के रूप में आएंगे।

उदाहरण

निम्नलिखित क्वेरी निम्न आउटपुट देगी।

SELECT salary from customers where salary between 2000 and 8500

उत्पादन

salary 
2000.00 
2000.00 
6500.00 
8500.00 
4500.00

मिन ()

न्यूनतम मूल्य दिए गए अभिव्यक्ति से आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी ग्राहकों की तालिका से दिए गए 'वेतन' की अभिव्यक्ति के लिए '1500.00' देगी।

Select MIN(salary)from CUSTOMERS

मैक्स ()

दी गई अभिव्यक्ति से अधिकतम मूल्य आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी ग्राहक तालिका से दिए गए 'वेतन' की अभिव्यक्ति के लिए '10000.00' देगी।

Select MAX(salary)from CUSTOMERS

SQRT ()

दिए गए संख्यात्मक अभिव्यक्ति का वर्गमूल आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित प्रश्न दिए गए 4 संख्यात्मक अभिव्यक्ति के लिए 2 देगा।

Select SQRT(4)

PI ()

पीआई मान आउटपुट के रूप में आएगा।

उदाहरण

पीआई मान के लिए निम्नलिखित क्वेरी 3.14159265358979 देगी।

Select PI()

अधिकतम सीमा()

दिया गया मूल्य दशमलव के पूर्णांक के बाद आउटपुट के रूप में आएगा जो कि अगला उच्चतम मूल्य है।

उदाहरण

निम्नलिखित क्वेरी दिए गए 123.25 मूल्य के लिए 124 देगा।

Select CEILING(123.25)

मंज़िल()

दिया गया मूल्य दशमलव के राउंड के बाद आउटपुट के रूप में आएगा जो कि अभिव्यक्ति से कम या उसके बराबर है।

उदाहरण

निम्नलिखित क्वेरी दिए गए 123.25 मान के लिए 123 देगा।

Select FLOOR(123.25)

लॉग ()

दी गई अभिव्यक्ति का प्राकृतिक लघुगणक आउटपुट के रूप में आएगा।

उदाहरण

निम्नलिखित क्वेरी दिए गए 1 मान के लिए 0 देगी।

Select LOG(1)