Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

SQL सर्वर में ALL का उपयोग करने के 3 तरीके

आप ALL . से परिचित हो सकते हैं SQL सर्वर में विकल्प। शायद आपने इसका उपयोग UNION . के साथ किया हो परिणाम सेट में लौटाए जा सकने वाले किसी भी डुप्लीकेट को शामिल करने के लिए ऑपरेटर।

लेकिन क्या आप जानते हैं कि ALL दो अन्य संदर्भों में भी इस्तेमाल किया जा सकता है?

ALL निम्नलिखित तीन संदर्भों में इस्तेमाल किया जा सकता है:

  • SELECT के तर्क के रूप में खंड।
  • UNION के तर्क के रूप में खंड।
  • एक लॉजिकल ऑपरेटर के रूप में जब एक स्केलर मान की तुलना एकल-स्तंभ मानों के सेट से की जाती है।

इनमें से प्रत्येक संदर्भ के उदाहरण इस प्रकार हैं।

ALL SELECT . में खंड

जब SELECT . के साथ प्रयोग किया जाता है खंड, ALL निर्दिष्ट करता है कि परिणाम सेट में डुप्लिकेट मान लौटाए जाते हैं।

आप शायद पहले से ही बिना जाने ही इसका इस्तेमाल कर रहे हैं।

T-SQL में, SELECT . के लिए सिंटैक्स खंड इस प्रकार है:

SELECT [ ALL | DISTINCT ]  
[ TOP ( expression ) [ PERCENT ] [ WITH TIES ] ]   
<select_list>   
<select_list> ::=   
    {   
      *   
      | { table_name | view_name | table_alias }.*   
      | {  
          [ { table_name | view_name | table_alias }. ]  
               { column_name | $IDENTITY | $ROWGUID }   
          | udt_column_name [ { . | :: } { { property_name | field_name }   
            | method_name ( argument [ ,...n] ) } ]  
          | expression  
          [ [ AS ] column_alias ]   
         }  
      | column_alias = expression   
    } [ ,...n ]

वह भाग जो जाता है [ ALL | DISTINCT ] इसका मतलब है कि आपको ALL . के बीच एक विकल्प मिलता है और DISTINCT .

वर्गाकार कोष्ठक का अर्थ है कि यह भाग वैकल्पिक है।

  • ALL निर्दिष्ट करता है कि परिणाम सेट में डुप्लिकेट पंक्तियाँ दिखाई दे सकती हैं।
  • DISTINCT निर्दिष्ट करता है कि परिणाम सेट में केवल अनन्य पंक्तियां दिखाई दे सकती हैं।

ALL डिफ़ॉल्ट मान है, इसलिए यदि आप ALL निर्दिष्ट नहीं करते हैं या DISTINCT , ALL उपयोग किया जाता है।

उदाहरण

तो निम्नलिखित दो कथन समतुल्य हैं:

SELECT DogName 
FROM Dogs;

SELECT ALL DogName 
FROM Dogs;

उदाहरण परिणाम:

+-----------+
| DogName   |
|-----------|
| Fetch     |
| Fluffy    |
| Wag       |
| Fetch     |
+-----------+
(4 rows affected)
+-----------+
| DogName   |
|-----------|
| Fetch     |
| Fluffy    |
| Wag       |
| Fetch     |
+-----------+
(4 rows affected)

दोनों परिणामों से पता चलता है कि "Fetch" नाम के दो कुत्ते हैं।

अगर हम ALL की अदला-बदली करते हैं DISTINCT . के लिए तर्क , "लाने" के लिए केवल एक पंक्ति लौटा दी जाएगी। ऐसा इसलिए है क्योंकि DISTINCT परिणाम सेट से किसी भी डुप्लिकेट मान को हटा देता है।

SELECT DISTINCT DogName 
FROM Dogs;

उदाहरण परिणाम:

+-----------+
| DogName   |
|-----------|
| Fetch     |
| Fluffy    |
| Wag       |
+-----------+
(3 rows affected)

ALL UNION . में खंड

ALL वही काम करता है जब UNION . के साथ प्रयोग किया जाता है खंड। यह निर्दिष्ट करता है कि परिणाम सेट में डुप्लिकेट मान लौटाए जाते हैं।

लेकिन जाहिर है, UNION SELECT . के लिए एक अलग क्लॉज है , इसलिए संदर्भ थोड़ा अलग है।

UNION खंड दो प्रश्नों के परिणामों को एक परिणाम सेट में जोड़ता है। आप इसका उपयोग ALL . के साथ या उसके बिना कर सकते हैं तर्क:

  • UNION ALL - डुप्लीकेट शामिल हैं।
  • UNION - डुप्लीकेट शामिल नहीं हैं।

उदाहरण

यहां UNION ALL का उपयोग करने का एक उदाहरण दिया गया है दो प्रश्नों को संयोजित करने के लिए।

चलिए Cats called नाम की एक टेबल जोड़ते हैं . तो हमारे पास दो टेबल हैं:Dogs और Cats

Dogs

+---------+-----------+
| DogId   | DogName   |
|---------+-----------|
| 1       | Fetch     |
| 2       | Fluffy    |
| 3       | Wag       |
| 1002    | Fetch     |
+---------+-----------+

Cats

+---------+-----------+
| CatId   | CatName   |
|---------+-----------|
| 1       | Meow      |
| 2       | Fluffy    |
| 3       | Scratch   |
+---------+-----------+

अब प्रत्येक तालिका से कुत्ते/बिल्ली का नाम चुनें और UNION ALL . का उपयोग करें दोनों तालिकाओं के परिणामों को संयोजित करने के लिए।

SELECT DogName AS PetName
FROM Dogs
UNION ALL
SELECT CatName
FROM Cats;

परिणाम:

+-----------+
| PetName   |
|-----------|
| Fetch     |
| Fluffy    |
| Wag       |
| Fetch     |
| Meow      |
| Fluffy    |
| Scratch   |
+-----------+
(7 rows affected)

इस मामले में, सात पंक्तियों को वापस कर दिया जाता है। हम देख सकते हैं कि "Fetch" दो बार लौटाया जाता है। ऐसा इसलिए है क्योंकि Fetch नाम के दो कुत्ते हैं।

एक ही नाम की एक बिल्ली और एक कुत्ता भी है:शराबी। (हम दूसरे की बिल्ली जानते हैं क्योंकि पिछले उदाहरण में Fluffy नामक केवल एक कुत्ता था)।

देखते हैं कि जब मैं ALL को हटाता हूं तो क्या होता है तर्क।

SELECT DogName AS PetName
FROM Dogs
UNION
SELECT CatName
FROM Cats;

परिणाम:

+-----------+
| PetName   |
|-----------|
| Fetch     |
| Fluffy    |
| Meow      |
| Scratch   |
| Wag       |
+-----------+
(5 rows affected)

इस बार केवल पाँच पंक्तियाँ लौटाई गई हैं। दोनों डुप्लीकेट हटा दिए गए हैं।

ध्यान दें कि यह लागू करने के लिए अलग है DISTINCT प्रत्येक व्यक्ति को SELECT बयान। अगर हमने ऐसा किया होता, तो Fluffy को दो बार लौटा दिया जाता, क्योंकि ALL केवल SELECT . के लिए लागू होगा यह कथन कि इसके विरुद्ध लागू किया जा रहा है (सम्मिलित परिणामों के लिए नहीं)।

मेरा मतलब समझाने के लिए यहां एक उदाहरण दिया गया है।

SELECT DISTINCT DogName AS PetName
FROM Dogs
UNION ALL
SELECT DISTINCT CatName
FROM Cats;

परिणाम:

+-----------+
| PetName   |
|-----------|
| Fetch     |
| Fluffy    |
| Wag       |
| Fluffy    |
| Meow      |
| Scratch   |
+-----------+
(6 rows affected)

ALL संचालिका

ALL सबक्वेरी द्वारा लौटाए गए मानों के एकल-स्तंभ सेट के साथ स्केलर मान की तुलना करने के लिए ऑपरेटर का उपयोग सबक्वेरी के साथ किया जा सकता है।

उदाहरण

एक पुनश्चर्या के रूप में, यहाँ हमारी दो तालिकाएँ हैं:

Dogs

+---------+-----------+
| DogId   | DogName   |
|---------+-----------|
| 1       | Fetch     |
| 2       | Fluffy    |
| 3       | Wag       |
| 1002    | Fetch     |
+---------+-----------+

Cats

+---------+-----------+
| CatId   | CatName   |
|---------+-----------|
| 1       | Meow      |
| 2       | Fluffy    |
| 3       | Scratch   |
+---------+-----------+

अब ALL . का उपयोग करके एक सबक्वेरी चलाते हैं ऑपरेटर।

SELECT 
    CatId,
    CatName
FROM Cats c 
WHERE c.CatName = ALL (SELECT DogName FROM Dogs);

परिणाम:

(0 rows affected)

इस मामले में, कोई पंक्तियाँ वापस नहीं की गईं। ऐसा इसलिए है क्योंकि ALL प्रत्येक . से सकारात्मक रूप से तुलना करने के लिए अदिश व्यंजक की आवश्यकता होती है वह मान जो सबक्वेरी द्वारा लौटाया जाता है।

इस मामले में, सबक्वेरी इतनी व्यापक थी कि Dogs . से सभी पंक्तियाँ तालिका वापस कर दी गई। इसके लिए यह आवश्यक होगा कि प्रत्येक कुत्ते के पास समान नाम वाली कम से कम एक संगत बिल्ली हो।

आइए सबक्वेरी को थोड़ा बदल दें।

SELECT 
    CatId,
    CatName
FROM Cats c 
WHERE c.CatName = ALL (
    SELECT DogName FROM Dogs 
    WHERE DogId = 2
    );

परिणाम:

+---------+-----------+
| CatId   | CatName   |
|---------+-----------|
| 2       | Fluffy    |
+---------+-----------+

इस बार मुझे एक सकारात्मक परिणाम मिला, क्योंकि सबक्वेरी द्वारा लौटाई गई सभी पंक्तियों में Cats में एक समान पंक्ति थी तालिका (इस मामले में, केवल एक पंक्ति)।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर का उपयोग करके रिक्त स्थान को शून्य मानों में कैसे परिवर्तित करें?

  2. क्या SQL सर्वर वेब अनुरोध भेज सकता है?

  3. तालिका मान पैरामीटर को कैसे बदलें

  4. मैं SQL सर्वर प्रबंधन स्टूडियो 2008 में जेनरेट स्क्रिप्ट कार्य को स्वचालित कैसे कर सकता हूं?

  5. SQL सर्वर 2005 एक अद्वितीय बाधा कैसे बनाएँ?