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

एसक्यूएल शुरुआती के लिए (!=) ऑपरेटर के बराबर नहीं है

SQL में, ऑपरेटर के बराबर नहीं (!= ) दो भावों की गैर-समानता की तुलना करता है। अर्थात्, यह परीक्षण करता है कि क्या एक व्यंजक नहीं है दूसरे व्यंजक के बराबर।

यदि दोनों में से कोई एक या दोनों ऑपरेंड NULL हैं , NULL लौटा दिया गया है।

एसक्यूएल में एक और ऑपरेटर के बराबर नहीं है (<> ), जो वही काम करता है। आप किसका उपयोग करते हैं, यह आपके DBMS पर निर्भर करता है कि आप किसका उपयोग करने में सबसे अधिक सहज हैं, और शायद यह भी कि क्या आपके संगठन में कोई कोडिंग परंपराएँ हैं जो यह निर्धारित करती हैं कि किसका उपयोग किया जाना चाहिए।

सोर्स टेबल

कल्पना कीजिए कि हमारे डेटाबेस में निम्न तालिका है। यह वह तालिका है जिसका उपयोग हम इस पृष्ठ पर उदाहरणों के लिए करेंगे।

SELECT * FROM Owners;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 3         | Nancy       | Simpson    | (489) 591-0408 | NULL              |
| 4         | Boris       | Trump      | (349) 611-8908 | NULL              |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
| 6         | Burt        | Tyson      | (309) 565-0112 | [email protected]  |
+-----------+-------------+------------+----------------+-------------------+

उदाहरण

अगर हम उन सभी स्वामियों की सूची वापस करना चाहते हैं जिनके पास OwnerId . नहीं है का 3 , हम यह कर सकते हैं:

SELECT *
FROM Owners
WHERE OwnerId != 3;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 4         | Boris       | Trump      | (349) 611-8908 | NULL              |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
| 6         | Burt        | Tyson      | (309) 565-0112 | [email protected]  |
+-----------+-------------+------------+----------------+-------------------+

हमारी क्वेरी ऑपरेटर के बराबर नहीं का उपयोग करती है (!= ) यह जांचने के लिए कि क्या OwnerId कॉलम 3 . के बराबर नहीं है . क्वेरी स्वामी संख्या 3 को छोड़कर सभी स्वामियों को लौटाती है।

स्ट्रिंग्स

स्ट्रिंग मान के साथ तुलना करते समय, स्ट्रिंग के चारों ओर उद्धरण चिह्नों का उपयोग करें। उदाहरण के लिए, यदि हम उन सभी मालिकों के बारे में जानकारी प्राप्त करना चाहते हैं जिनका पहला नाम होमर नहीं है, तो हम निम्न कार्य कर सकते हैं:

SELECT *
FROM Owners
WHERE FirstName != 'Homer';

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 3         | Nancy       | Simpson    | (489) 591-0408 | NULL              |
| 4         | Boris       | Trump      | (349) 611-8908 | NULL              |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
| 6         | Burt        | Tyson      | (309) 565-0112 | [email protected]  |
+-----------+-------------+------------+----------------+-------------------+

एकाधिक शर्तें

यदि आपके पास एकाधिक शर्तें हैं, तो आप एकाधिक ऑपरेटरों का उपयोग कर सकते हैं (चाहे एक ही ऑपरेटर या अलग दोनों)।

इस तरह:

SELECT * FROM Owners 
WHERE OwnerId != 1 AND OwnerId != 3;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 4         | Boris       | Trump      | (349) 611-8908 | NULL              |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
| 6         | Burt        | Tyson      | (309) 565-0112 | [email protected]  |
+-----------+-------------+------------+----------------+-------------------+

एक बार जब आप अधिक शर्तों का उपयोग करना शुरू कर देते हैं, तो आपको उन स्थितियों को घेरने के लिए कोष्ठकों का उपयोग करना चाहिए जिनका आप पहले मूल्यांकन करना चाहते हैं। यदि आप ऐसा नहीं करते हैं, तो आप देख सकते हैं कि आपको अप्रत्याशित परिणाम मिल सकते हैं, क्योंकि शर्तों का मूल्यांकन उस क्रम में किया जा रहा है जिसका आपने इरादा नहीं किया था।

शर्त को नकारना

यदि आप NOT का उपयोग करते हैं ऑपरेटर द्वारा प्रदान की गई शर्त को नकारने के लिए ऑपरेटर के बराबर नहीं है, तो आप अंत में बराबर के परिणाम प्राप्त करेंगे (= ) ऑपरेटर:

SELECT *
FROM Owners
WHERE NOT FirstName != 'Homer';

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
+-----------+-------------+------------+----------------+-------------------+

इस मामले में, आप केवल बराबर का उपयोग कर रहे हैं (= ) ऑपरेटर, इस तरह:

SELECT *
FROM Owners
WHERE FirstName = 'Homer';

बेशक, इसे NOT . से नकारा जा सकता है ऑपरेटर, जो तब हमें वही परिणाम देगा जो इसके बराबर नहीं है (!= ) ऑपरेटर हमें देता है:

SELECT *
FROM Owners
WHERE NOT FirstName = 'Homer';

पूर्ण मान

आपने देखा होगा कि हमारी मूल नमूना तालिका में कुछ NULL हैं Email में मान कॉलम।

एक कॉलम जिसमें NULL . है यानी इसका कोई मूल्य नहीं है। यह 0 . से अलग है या false , या यहां तक ​​​​कि एक खाली स्ट्रिंग।

NULL . से तुलना करने के लिए आप नॉट बराबर ऑपरेटर का उपयोग नहीं कर सकते हैं . दरअसल, यह आपके डीबीएमएस और इसके कॉन्फ़िगरेशन पर निर्भर हो सकता है। लेकिन अभी के लिए, आइए देखें कि अगर मैं Email . की तुलना करने की कोशिश करता हूं तो क्या होता है? कॉलम से NULL

SELECT * FROM Owners 
WHERE Email != NULL;

परिणाम:

(0 rows affected)

गैर के लिए परीक्षण करने का तरीका-NULL मानों का उपयोग करना है IS NOT NULL

इसलिए, हमें उपरोक्त कथन को निम्नानुसार फिर से लिखना होगा।

SELECT * FROM Owners 
WHERE Email IS NOT NULL;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
| 6         | Burt        | Tyson      | (309) 565-0112 | [email protected]  |
+-----------+-------------+------------+----------------+-------------------+

अब हमें केवल वही पंक्तियाँ मिलती हैं जो NULL . नहीं हैं Email . में कॉलम।

यदि आप रुचि रखते हैं, तो देखें SQL Server ANSI_NULLS Explained यह देखने के लिए कि आप NULL का तरीका कैसे बदल सकते हैं SQL सर्वर में मानों का इलाज किया जाता है।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. विज़ुअलाइज़िंग डेटा

  2. लूप के बिना एक सेट या अनुक्रम उत्पन्न करें - भाग 1

  3. SQL कथन में चयन करें

  4. हैलोवीन समस्या - भाग 4

  5. अनुप्रयोगों के बीच डेटाबेस संरचना को सिंक्रनाइज़ करना