SQLite क्वेरी: चयन करें, कहां, सीमा, ऑफसेट, गणना, समूह द्वारा

SQL क्वेरीज़ लिखने के लिए SQLite डेटाबेस में, आपको यह जानना होगा कि SELECT, FROM, WHERE, GROUP BY, ORDER BY, और LIMIT क्लॉज कैसे काम करते हैं और उनका उपयोग कैसे किया जाता है।

इस ट्यूटोरियल के दौरान, आप सीखेंगे कि इन क्लॉज़ का उपयोग कैसे करें और कैसे लिखें SQLite खंड।

चयन के साथ डेटा पढ़ना

SELECT क्लॉज़ वह मुख्य कथन है जिसका उपयोग आप किसी क्वेरी के लिए करते हैं SQLite डेटाबेस। SELECT क्लॉज में, आप बताते हैं कि क्या चुनना है। लेकिन सेलेक्ट क्लॉज से पहले, आइए देखें कि हम FROM क्लॉज का उपयोग करके कहां से डेटा चुन सकते हैं।

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

ध्यान दें कि, निम्नलिखित सभी उदाहरणों के लिए, आपको sqlite3.exe चलाना होगा और नमूना डेटाबेस से कनेक्शन खोलना होगा:

चरण 1) इस चरण में,

  1. मेरा कंप्यूटर खोलें और निम्नलिखित निर्देशिका पर जाएँ “सी:\sqlite" तथा
  2. फिर खोलें “sqlite3.exe"

चयन के साथ डेटा पढ़ना

चरण 2) डेटाबेस खोलें “ट्यूटोरियल्ससैंपलDB.db"निम्न आदेश द्वारा:

चयन के साथ डेटा पढ़ना

अब आप डेटाबेस पर किसी भी प्रकार की क्वेरी चलाने के लिए तैयार हैं।

SELECT क्लॉज़ में, आप न केवल कॉलम नाम चुन सकते हैं, बल्कि आपके पास यह निर्दिष्ट करने के लिए कई अन्य विकल्प भी हैं कि क्या चुनना है। जैसा कि निम्नलिखित है:

चुनते हैं *

यह कमांड FROM क्लॉज में सभी संदर्भित तालिकाओं (या सबक्वेरीज़) से सभी कॉलम का चयन करेगा। उदाहरण के लिए:

SELECT * 
FROM Students
INNER JOIN Departments ON Students.DepartmentId = Departments.DepartmentId;

यह दोनों तालिकाओं students और department से सभी कॉलमों का चयन करेगा:

चयन के साथ डेटा पढ़ना

तालिकानाम का चयन करें.*

यह केवल टेबल “tablename” से सभी कॉलम का चयन करेगा। उदाहरण के लिए:

SELECT Students.*
FROM Students
INNER JOIN Departments ON Students.DepartmentId = Departments.DepartmentId;

यह केवल students तालिका से सभी कॉलम का चयन करेगा:

चयन के साथ डेटा पढ़ना

शाब्दिक मूल्य

शाब्दिक मान एक स्थिर मान है जिसे चयन कथन में निर्दिष्ट किया जा सकता है। आप शाब्दिक मानों का उपयोग सामान्य रूप से उसी तरह कर सकते हैं जिस तरह आप SELECT क्लॉज़ में कॉलम नामों का उपयोग करते हैं। ये शाब्दिक मान SQL क्वेरी द्वारा लौटाई गई पंक्तियों से प्रत्येक पंक्ति के लिए प्रदर्शित किए जाएँगे।

यहां विभिन्न शाब्दिक मानों के कुछ उदाहरण दिए गए हैं जिन्हें आप चुन सकते हैं:

  • संख्यात्मक शाब्दिक - किसी भी प्रारूप में संख्याएँ जैसे 1, 2.55, ... आदि।
  • स्ट्रिंग लिटरल - कोई भी स्ट्रिंग 'USA', 'यह एक नमूना पाठ है', ... आदि।
  • शून्य - शून्य मान.
  • Current_TIME – यह आपको वर्तमान समय बताएगा।
  • CURRENT_DATE – यह आपको वर्तमान दिनांक देगा.

यह कुछ स्थितियों में उपयोगी हो सकता है जहाँ आपको सभी लौटाई गई पंक्तियों के लिए एक स्थिर मान चुनना होता है। उदाहरण के लिए, यदि आप Students तालिका से सभी छात्रों का चयन करना चाहते हैं, जिसमें एक नया कॉलम है जिसे country कहा जाता है जिसमें “USA” मान होता है, तो आप यह कर सकते हैं:

SELECT *, 'USA' AS Country FROM Students;

इससे आपको सभी छात्रों के कॉलम मिलेंगे, साथ ही एक नया कॉलम “देश” भी मिलेगा:

चयन के साथ डेटा पढ़ना

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

नाम और उपनाम

उपनाम कॉलम के लिए एक नया नाम है जो आपको नए नाम के साथ कॉलम चुनने देता है। कॉलम उपनामों को “AS” कीवर्ड का उपयोग करके निर्दिष्ट किया जाता है।

उदाहरण के लिए, यदि आप चाहते हैं कि StudentName कॉलम को “StudentName” के बजाय “StudentName” के रूप में लौटाया जाए, तो आप इसे इस तरह एक उपनाम दे सकते हैं:

SELECT StudentName AS 'Student Name' FROM Students;

इससे आपको छात्रों के नाम “StudentName” के बजाय “StudentName” के रूप में मिलेंगे, जैसे:

नाम और उपनाम

ध्यान दें कि, कॉलम का नाम अभी भी “छात्रनाम“; कॉलम StudentName अभी भी वही है, यह उपनाम से नहीं बदलता है।

उपनाम स्तंभ नाम को नहीं बदलेगा; यह केवल SELECT खंड में प्रदर्शन नाम को बदल देगा।

इसके अलावा, ध्यान रखें कि, कीवर्ड “AS” वैकल्पिक है, आप इसके बिना भी उपनाम नाम डाल सकते हैं, कुछ इस तरह:

SELECT StudentName 'Student Name' FROM Students;

और यह आपको पिछली क्वेरी के समान ही आउटपुट देगा:

नाम और उपनाम

आप सिर्फ़ कॉलम ही नहीं, बल्कि टेबल को भी उपनाम दे सकते हैं। उसी कीवर्ड “AS” के साथ। उदाहरण के लिए, आप यह कर सकते हैं:

SELECT s.* FROM Students AS s;

इससे आपको तालिका में सभी कॉलम मिल जाएंगे छात्र:

नाम और उपनाम

यह बहुत उपयोगी हो सकता है यदि आप एक से अधिक टेबल को जोड़ रहे हैं; क्वेरी में पूरा टेबल नाम दोहराने के बजाय, आप प्रत्येक टेबल को एक छोटा उपनाम नाम दे सकते हैं। उदाहरण के लिए, निम्न क्वेरी में:

SELECT Students.StudentName, Departments.DepartmentName
FROM Students
INNER JOIN Departments ON Students.DepartmentId = Departments.DepartmentId;

यह क्वेरी “छात्र” तालिका से प्रत्येक छात्र का नाम और “विभाग” तालिका से उसके विभाग का नाम चुनेगी:

नाम और उपनाम

हालाँकि, उसी क्वेरी को इस तरह लिखा जा सकता है:

SELECT s.StudentName, d.DepartmentName
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;
  • हमने विद्यार्थियों की तालिका को उपनाम “s” और विभागों की तालिका को उपनाम “d” दिया।
  • फिर हमने पूरी तालिका के नाम का उपयोग करने के बजाय, उन्हें संदर्भित करने के लिए उनके उपनामों का उपयोग किया।
  • INNER JOIN एक शर्त का उपयोग करके दो या अधिक तालिकाओं को एक साथ जोड़ता है। हमारे उदाहरण में, हमने DepartmentId कॉलम के साथ Students तालिका को Departments तालिका के साथ जोड़ा। INNER JOIN के लिए एक गहन व्याख्या भी है “SQLite जॉइन्स” ट्यूटोरियल।

इससे आपको पिछली क्वेरी जैसा ही सटीक आउटपुट मिलेगा:

नाम और उपनाम

कहां

जैसा कि हमने पिछले अनुभाग में देखा था, FROM क्लॉज के साथ SELECT क्लॉज का उपयोग करके SQL क्वेरी लिखने से आपको टेबल की सभी पंक्तियाँ मिल जाएँगी। हालाँकि, यदि आप लौटाए गए डेटा को फ़िल्टर करना चाहते हैं, तो आपको “WHERE” क्लॉज जोड़ना होगा।

WHERE क्लॉज़ का उपयोग परिणाम सेट को फ़िल्टर करने के लिए किया जाता है SQL क्वेरीWHERE क्लॉज़ इस प्रकार काम करता है:

  • WHERE क्लॉज़ में, आप एक “एक्सप्रेशन” निर्दिष्ट कर सकते हैं।
  • उस अभिव्यक्ति का मूल्यांकन FROM खंड में निर्दिष्ट तालिका(ओं) से लौटी प्रत्येक पंक्ति के लिए किया जाएगा।
  • अभिव्यक्ति का मूल्यांकन बूलियन अभिव्यक्ति के रूप में किया जाएगा, जिसका परिणाम सत्य, असत्य या शून्य होगा।
  • फिर केवल वे पंक्तियाँ लौटाई जाएंगी जिनके लिए अभिव्यक्ति का मूल्यांकन सत्य मान के साथ किया गया था, तथा गलत या शून्य परिणाम वाली पंक्तियों को अनदेखा कर दिया जाएगा तथा परिणाम सेट में शामिल नहीं किया जाएगा।
  • WHERE क्लॉज़ का उपयोग करके परिणाम सेट को फ़िल्टर करने के लिए, आपको अभिव्यक्तियों और ऑपरेटरों का उपयोग करना होगा।

ऑपरेटरों की सूची SQLite और उनका उपयोग कैसे करें

अगले अनुभाग में, हम बताएंगे कि आप अभिव्यक्ति और ऑपरेटरों का उपयोग करके कैसे फ़िल्टर कर सकते हैं।

अभिव्यक्ति एक या एक से अधिक शाब्दिक मान या कॉलम हैं जो एक ऑपरेटर के साथ एक दूसरे के साथ संयुक्त होते हैं।

ध्यान दें कि, आप SELECT खंड और WHERE खंड दोनों में अभिव्यक्तियों का उपयोग कर सकते हैं।

निम्नलिखित उदाहरणों में, हम select Clause और WHERE Clause दोनों में अभिव्यक्तियों और ऑपरेटरों को आज़माएँगे। ताकि आपको दिखाया जा सके कि वे कैसे काम करते हैं।

विभिन्न प्रकार के अभिव्यक्तियाँ और ऑपरेटर हैं जिन्हें आप निम्नानुसार निर्दिष्ट कर सकते हैं:

SQLite संयोजन ऑपरेटर “||”

इस ऑपरेटर का उपयोग एक या अधिक शाब्दिक मानों या स्तंभों को एक दूसरे के साथ संयोजित करने के लिए किया जाता है। यह सभी संयोजित शाब्दिक मानों या स्तंभों से परिणामों की एक स्ट्रिंग तैयार करेगा। उदाहरण के लिए:

SELECT 'Id with Name: '|| StudentId || StudentName AS StudentIdWithName
FROM Students;

यह एक नए उपनाम में संयोजित हो जाएगा “छात्रआईडीविथनाम"

  • शाब्दिक स्ट्रिंग मान “नाम सहित आईडी: "
  • " के मूल्य के साथस्टूडेंट आईडी” कॉलम और
  • " से मूल्य के साथछात्रनाम" स्तंभ

SQLite संयोजन ऑपरेटर '||'

SQLite CAST ऑपरेटर:

CAST ऑपरेटर का उपयोग किसी मान को एक डेटा प्रकार से दूसरे में बदलने के लिए किया जाता है डाटा प्रकार.

उदाहरण के लिए, यदि आपके पास एक संख्यात्मक मान स्ट्रिंग मान के रूप में संग्रहीत है जैसे ” '12.5' ” और आप इसे एक संख्यात्मक मान में बदलना चाहते हैं तो आप ऐसा करने के लिए CAST ऑपरेटर का उपयोग कर सकते हैं “कास्ट ('12.5' ​​वास्तविक रूप में)“. या यदि आपके पास 12.5 जैसा दशमलव मान है, और आपको केवल पूर्णांक भाग प्राप्त करने की आवश्यकता है, तो आप इसे इस तरह पूर्णांक में डाल सकते हैं “CAST(12.5 AS INTEGER)”।

उदाहरण

निम्नलिखित कमांड में हम विभिन्न मानों को अन्य डेटा प्रकारों में परिवर्तित करने का प्रयास करेंगे:

SELECT CAST('12.5' AS REAL) ToReal, CAST(12.5 AS INTEGER) AS ToInteger;

इससे आपको मिलेगा:

SQLite कास्ट Operaटो

परिणाम निम्नलिखित है:

  • CAST('12.5' ​​AS REAL) - मान '12.5' ​​एक स्ट्रिंग मान है, इसे REAL मान में परिवर्तित किया जाएगा।
  • CAST(12.5 AS INTEGER) – मान 12.5 एक दशमलव मान है, इसे पूर्णांक मान में परिवर्तित किया जाएगा। दशमलव भाग को छोटा कर दिया जाएगा, और यह 12 हो जाएगा।

SQLite अंकगणित Operaटोर्स:

दो या अधिक संख्यात्मक शाब्दिक मान या संख्यात्मक कॉलम लें और एक संख्यात्मक मान लौटाएँ। इसमें समर्थित अंकगणितीय ऑपरेटर SQLite यह है:

  • जोड़ना "+” – दो ऑपरेंडों का योग दीजिए।
  • घटाव “-” – दो ऑपरेंडों को घटाता है और परिणाम में अंतर बताता है।
  • गुणन “*” – दो ऑपरेंडों का गुणनफल।
  • अनुस्मारक (मॉड्यूलो) “%” – एक ऑपरेंड को दूसरे ऑपरेंड से विभाजित करने पर प्राप्त शेषफल देता है।
  • विभाजन "/” – बाएँ ऑपरेंड को दाएँ ऑपरेंड से विभाजित करने से प्राप्त भागफल परिणाम लौटाता है।

उदाहरण:

निम्नलिखित उदाहरण में, हम पाँच अंकगणितीय ऑपरेटरों को समान संख्यात्मक मानों के साथ आज़माएँगे।

चयन खंड:

SELECT 25+6, 25-6, 25*6, 25%6, 25/6;

इससे आपको मिलेगा:

SQLite अंकगणित Operaमरोड़

ध्यान दें कि हमने यहाँ FROM क्लॉज़ के बिना SELECT कथन का उपयोग कैसे किया। और इसकी अनुमति है SQLite जब तक हम शाब्दिक मूल्यों का चयन करते हैं।

SQLite तुलना ऑपरेटरों

दो ऑपरेंडों की एक दूसरे से तुलना करें और निम्नानुसार सत्य या असत्य लौटाएं:

  • "<” – यदि बायां ऑपरेंड दायां ऑपरेंड से छोटा है तो सत्य लौटाता है।
  • "<=” – यदि बायां ऑपरेंड दाएँ ऑपरेंड से छोटा या बराबर है तो सत्य लौटाता है।
  • ">” – यदि बायां ऑपरेंड दायां ऑपरेंड से बड़ा है तो सत्य लौटाता है।
  • ">=” – यदि बायां ऑपरेंड दाएँ ऑपरेंड से बड़ा या बराबर है तो सत्य लौटाता है।
  • "=" तथा "==” – यदि दो ऑपरेंड बराबर हैं तो true लौटाता है। ध्यान दें कि दोनों ऑपरेटर समान हैं, और उनके बीच कोई अंतर नहीं है।
  • "!=" तथा "<>” – यदि दो ऑपरेंड बराबर नहीं हैं तो true लौटाता है। ध्यान दें कि दोनों ऑपरेटर समान हैं, और उनके बीच कोई अंतर नहीं है।

ध्यान दें कि, SQLite सत्य मान को 1 तथा असत्य मान को 0 से व्यक्त करता है।

उदाहरण:

SELECT 
  10<6 AS '<', 10<=6 AS '<=',
  10>6 AS '>', 10>=6 AS '>=',
  10=6 AS '=', 10==6 AS '==',
  10!=6 AS '!=', 10<>6 AS '<>';

इससे कुछ इस तरह का परिणाम मिलेगा:

SQLite तुलना Operaमरोड़

SQLite पैटर्न मिलान ऑपरेटर

"तरह” – का उपयोग पैटर्न मिलान के लिए किया जाता है। “ का उपयोग करकेपसंद“, आप वाइल्डकार्ड का उपयोग करके निर्दिष्ट पैटर्न से मेल खाने वाले मानों की खोज कर सकते हैं।

बाईं ओर का ऑपरेंड या तो स्ट्रिंग लिटरल मान या स्ट्रिंग कॉलम हो सकता है। पैटर्न को निम्न प्रकार से निर्दिष्ट किया जा सकता है:

  • इसमें पैटर्न शामिल है। उदाहरण के लिए, छात्र का नाम LIKE '%a%' - यह उन छात्रों के नामों की खोज करेगा जिनमें StudentName कॉलम में किसी भी स्थान पर "a" अक्षर शामिल है।
  • पैटर्न से शुरू होता है। उदाहरण के लिए, “छात्र का नाम LIKE 'a%'” – “a” अक्षर से शुरू होने वाले छात्रों के नाम खोजें।
  • पैटर्न के साथ समाप्त होता है। उदाहरण के लिए, “छात्रनाम LIKE '%a'” – उन छात्रों के नाम खोजें जिनका अंत “a” अक्षर से होता है।
  • अंडरस्कोर अक्षर “_” का उपयोग करके स्ट्रिंग में किसी भी एकल वर्ण का मिलान करना। उदाहरण के लिए, “छात्र का नाम 'J___' जैसा” – ऐसे छात्रों के नाम खोजें जिनकी लंबाई 4 अक्षरों की हो। इसकी शुरुआत “J” अक्षर से होनी चाहिए और “J” अक्षर के बाद कोई भी तीन और अक्षर हो सकते हैं।

पैटर्न मिलान के उदाहरण:

  1. 'j' अक्षर से शुरू होने वाले छात्रों के नाम प्राप्त करें:
    SELECT StudentName FROM Students WHERE StudentName LIKE 'j%';

    रिजल्ट:

    SQLite पैटर्न मिलान Operaमरोड़

  2. 'y' अक्षर से समाप्त होने वाले छात्रों के नाम प्राप्त करें:
    SELECT StudentName FROM Students WHERE StudentName LIKE '%y';

    रिजल्ट:

    SQLite पैटर्न मिलान Operaमरोड़

  3. 'n' अक्षर वाले छात्रों के नाम प्राप्त करें:
    SELECT StudentName FROM Students WHERE StudentName LIKE '%n%';

    रिजल्ट:

    SQLite पैटर्न मिलान Operaमरोड़

“ग्लोब” - LIKE ऑपरेटर के बराबर है, लेकिन GLOB केस सेंसिटिव है, LIKE ऑपरेटर के विपरीत। उदाहरण के लिए, निम्नलिखित दो कमांड अलग-अलग परिणाम लौटाएंगे:

SELECT 'Jack' GLOB 'j%';
SELECT 'Jack' LIKE 'j%';

इससे आपको मिलेगा:

SQLite पैटर्न मिलान Operaमरोड़

  • पहला कथन 0 (गलत) लौटाता है क्योंकि GLOB ऑपरेटर केस सेंसिटिव है, इसलिए 'j' 'J' के बराबर नहीं है। हालाँकि, दूसरा कथन 1 (सत्य) लौटाएगा क्योंकि LIKE ऑपरेटर केस सेंसिटिव नहीं है, इसलिए 'j' 'J' के बराबर है।

अन्य ऑपरेटर:

SQLite और

एक तार्किक ऑपरेटर जो एक या अधिक अभिव्यक्तियों को जोड़ता है। यह तभी सत्य लौटाएगा, जब सभी अभिव्यक्तियाँ “सत्य” मान देंगी। हालाँकि, यह तभी असत्य लौटाएगा, जब सभी अभिव्यक्तियाँ “असत्य” मान देंगी।

उदाहरण:

निम्नलिखित क्वेरी उन छात्रों की खोज करेगी जिनकी StudentId > 5 है और StudentName अक्षर N से शुरू होता है, लौटाए गए छात्रों को दो शर्तों को पूरा करना होगा:

SELECT * 
FROM Students 
WHERE (StudentId > 5) AND (StudentName LIKE 'N%');

SQLite और Operaटो

आउटपुट के तौर पर, ऊपर दिए गए स्क्रीनशॉट में, यह आपको सिर्फ़ “नैन्सी” देगा। नैन्सी एकमात्र छात्रा है जो दोनों शर्तों को पूरा करती है।

SQLite OR

एक तार्किक ऑपरेटर जो एक या अधिक अभिव्यक्तियों को जोड़ता है, ताकि यदि संयुक्त ऑपरेटरों में से एक सत्य देता है, तो यह सत्य लौटाएगा। हालाँकि, यदि सभी अभिव्यक्तियाँ असत्य देती हैं, तो यह असत्य लौटाएगा।

उदाहरण:

निम्नलिखित क्वेरी उन छात्रों की खोज करेगी जिनकी StudentId > 5 है या StudentName अक्षर N से शुरू होता है, लौटाए गए छात्रों को कम से कम एक शर्त पूरी करनी होगी:

SELECT * 
FROM Students 
WHERE (StudentId > 5) OR (StudentName LIKE 'N%');

इससे आपको मिलेगा:

SQLite OR Operaटो

आउटपुट के रूप में, उपरोक्त स्क्रीनशॉट में, यह आपको एक छात्र का नाम देगा जिसके नाम में अक्षर “n” होगा और छात्र आईडी का मान 5 से अधिक होगा।

जैसा कि आप देख सकते हैं, परिणाम AND ऑपरेटर वाली क्वेरी से भिन्न है।

SQLite बीच

BETWEEN का उपयोग उन मानों को चुनने के लिए किया जाता है जो दो मानों की सीमा के भीतर होते हैं। उदाहरण के लिए, “Y और Z के बीच X” सत्य (1) लौटाएगा यदि मान X दो मान Y और Z के बीच है। अन्यथा, यह असत्य (0) लौटाएगा। “Y और Z के बीच X” इसके बराबर है “X >= Y और X <= Z“, X, Y से बड़ा या बराबर होना चाहिए और X, Z से छोटा या बराबर होना चाहिए।

उदाहरण:

निम्नलिखित उदाहरण क्वेरी में, हम 5 से 8 के बीच Id मान वाले छात्रों को प्राप्त करने के लिए एक क्वेरी लिखेंगे:

SELECT *
FROM Students
WHERE StudentId BETWEEN 5 AND 8;

इससे केवल आईडी 5, 6, 7 और 8 वाले विद्यार्थियों को ही जानकारी मिलेगी:

SQLite बीच Operaटो

SQLite IN

एक ऑपरेंड और ऑपरेंड की एक सूची लेता है। यदि पहला ऑपरेंड मान सूची में से किसी एक ऑपरेंड के मान के बराबर है, तो यह सत्य लौटाएगा। यदि ऑपरेंड की सूची में उसके मानों के भीतर पहला ऑपरेंड मान शामिल है, तो IN ऑपरेटर सत्य (1) लौटाता है। अन्यथा, यह गलत (0) लौटाएगा।

इस कदर: "कॉल IN(x, y, z)“. यह इसके बराबर है” (col=x) या (col=y) या (col=z) ".

उदाहरण:

निम्नलिखित क्वेरी केवल आईडी 2, 4, 6, 8 वाले छात्रों का चयन करेगी:

SELECT * 
FROM Students
WHERE StudentId IN(2, 4, 6, 8);

इस कदर:

SQLite IN Operaटो

पिछली क्वेरी निम्नलिखित क्वेरी के समान ही परिणाम देगी क्योंकि वे समतुल्य हैं:

SELECT * 
FROM Students
WHERE (StudentId = 2) OR (StudentId =  4) OR (StudentId =  6) OR (StudentId = 8);

दोनों क्वेरीज़ सटीक आउटपुट देती हैं। हालाँकि, दोनों क्वेरीज़ के बीच अंतर यह है कि पहली क्वेरी में हमने “IN” ऑपरेटर का इस्तेमाल किया था। दूसरी क्वेरी में, हमने कई “OR” ऑपरेटर का इस्तेमाल किया।

IN ऑपरेटर कई OR ऑपरेटरों का उपयोग करने के बराबर है।जहां स्टूडेंटआईडी IN(2, 4, 6, 8)” के बराबर है ” जहाँ (छात्र आईडी = 2) या (छात्र आईडी = 4) या (छात्र आईडी = 6) या (छात्र आईडी = 8);"

इस कदर:

SQLite IN Operaटो

SQLite अंदर नही

“NOT IN” ऑपरेंड IN ऑपरेटर के विपरीत है। लेकिन समान सिंटैक्स के साथ; यह एक ऑपरेंड और ऑपरेंड की एक सूची लेता है। यदि पहला ऑपरेंड मान सूची में से किसी एक ऑपरेंड के मान के बराबर नहीं है, तो यह सत्य लौटाएगा। यानी, यदि ऑपरेंड की सूची में पहला ऑपरेंड शामिल नहीं है, तो यह सत्य (0) लौटाएगा। इस तरह: “col NOT IN(x, y, z)“. यह “ के बराबर है(col<>x) और (col<>y) और (col<>z)".

उदाहरण:

निम्नलिखित क्वेरी उन विद्यार्थियों का चयन करेगी जिनकी आईडी इन आईडी 2, 4, 6, 8 में से किसी एक के बराबर नहीं है:

SELECT * 
FROM Students
WHERE StudentId NOT IN(2, 4, 6, 8);

इस तरह

SQLite अंदर नही Operaटो

पिछली क्वेरी का परिणाम हम निम्नलिखित क्वेरी के समान ही देते हैं क्योंकि वे समतुल्य हैं:

SELECT * 
FROM Students
WHERE (StudentId <> 2) AND (StudentId <> 4) AND (StudentId <> 6) AND (StudentId <> 8);

इस कदर:

SQLite अंदर नही Operaटो

उपरोक्त स्क्रीनशॉट में,

हमने छात्रों की एक सूची प्राप्त करने के लिए कई बराबर नहीं ऑपरेटरों “<>” का उपयोग किया, जो निम्नलिखित आईडी 2, 4, 6, और 8 में से किसी के बराबर नहीं हैं। यह क्वेरी आईडी की इन सूचियों के अलावा अन्य सभी छात्रों को वापस कर देगी।

SQLite मौजूद है

EXISTS ऑपरेटर कोई ऑपरेंड नहीं लेता; यह उसके बाद केवल SELECT क्लॉज़ लेता है। यदि SELECT क्लॉज़ से कोई भी पंक्ति वापस आती है, तो EXISTS ऑपरेटर true (1) लौटाएगा, और यदि SELECT क्लॉज़ से कोई भी पंक्ति वापस नहीं आती है, तो यह false (0) लौटाएगा।

उदाहरण:

निम्नलिखित उदाहरण में, यदि विभाग आईडी students तालिका में मौजूद है, तो हम विभाग का नाम चुनेंगे:

SELECT DepartmentName
FROM Departments AS d
WHERE EXISTS (SELECT DepartmentId FROM Students AS s WHERE d.DepartmentId = s.DepartmentId);

इससे आपको मिलेगा:

SQLite मौजूद है Operaटो

केवल तीन विभाग “आईटी, भौतिकी और कला” लौटा दिया जाएगा। और विभाग का नाम “मठ” वापस नहीं किया जाएगा क्योंकि उस विभाग में कोई छात्र नहीं है, इसलिए विभाग आईडी छात्रों की तालिका में मौजूद नहीं है। इसीलिए EXISTS ऑपरेटर ने “ को अनदेखा कर दिया।मठ" विभाग।

SQLite नहीं

Revयह पिछले ऑपरेटर के परिणाम को दर्शाता है जो उसके बाद आता है। उदाहरण के लिए:

  • NOT BETWEEN - यदि BETWEEN गलत लौटाता है तो यह सत्य लौटाएगा और इसके विपरीत।
  • NOT LIKE - यदि LIKE गलत लौटाता है तो यह सत्य लौटाएगा और इसके विपरीत।
  • NOT GLOB - यदि GLOB गलत लौटाता है तो यह सत्य लौटाएगा और इसके विपरीत।
  • NOT EXISTS - यदि EXISTS गलत लौटाता है तो यह सत्य लौटाएगा और इसके विपरीत।

उदाहरण:

निम्नलिखित उदाहरण में, हम EXISTS ऑपरेटर के साथ NOT ऑपरेटर का उपयोग उन विभागों के नाम प्राप्त करने के लिए करेंगे जो Students तालिका में मौजूद नहीं हैं, जो EXISTS ऑपरेटर का उल्टा परिणाम है। इसलिए, खोज DepartmentId के माध्यम से की जाएगी जो विभाग तालिका में मौजूद नहीं है।

SELECT DepartmentName
FROM Departments AS d
WHERE NOT EXISTS (SELECT DepartmentId 
                  FROM Students AS s 
                  WHERE d.DepartmentId = s.DepartmentId);

उत्पादन:

SQLite नहीं Operaटो

केवल विभाग “मठ ” वापस कर दिया जाएगा। क्योंकि “मठ” विभाग एकमात्र विभाग है, जो छात्रों की तालिका में मौजूद नहीं है।

सीमित करना और आदेश देना

SQLite व्यवस्था

SQLite ऑर्डर आपके परिणाम को एक या अधिक अभिव्यक्तियों के आधार पर क्रमबद्ध करना है। परिणाम सेट को क्रमबद्ध करने के लिए, आपको निम्न प्रकार से ORDER BY क्लॉज़ का उपयोग करना होगा:

  • सबसे पहले, आपको ORDER BY क्लॉज़ निर्दिष्ट करना होगा।
  • ORDER BY क्लॉज को क्वेरी के अंत में निर्दिष्ट किया जाना चाहिए; इसके बाद केवल LIMIT क्लॉज निर्दिष्ट किया जा सकता है।
  • डेटा को क्रमित करने के लिए अभिव्यक्ति निर्दिष्ट करें, यह अभिव्यक्ति एक स्तंभ नाम या एक अभिव्यक्ति हो सकती है।
  • अभिव्यक्ति के बाद, आप वैकल्पिक सॉर्ट दिशा निर्दिष्ट कर सकते हैं। डेटा को अवरोही क्रम में क्रमबद्ध करने के लिए DESC या डेटा को आरोही क्रम में क्रमबद्ध करने के लिए ASC। यदि आपने उनमें से कोई भी निर्दिष्ट नहीं किया है, तो डेटा आरोही क्रम में क्रमबद्ध किया जाएगा।
  • आप एक दूसरे के बीच “,” का उपयोग करके अधिक अभिव्यक्तियाँ निर्दिष्ट कर सकते हैं।

उदाहरण

निम्नलिखित उदाहरण में, हम सभी विद्यार्थियों का चयन उनके नाम के अनुसार अवरोही क्रम में, फिर विभाग के नाम के अनुसार आरोही क्रम में करेंगे:

SELECT s.StudentName, d.DepartmentName
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId
ORDER BY d.DepartmentName ASC , s.StudentName DESC;

इससे आपको मिलेगा:

सीमित करना और आदेश देना

  • SQLite सबसे पहले सभी छात्रों को उनके विभाग के नाम के अनुसार आरोही क्रम में व्यवस्थित किया जाएगा
  • फिर प्रत्येक विभाग के नाम के लिए, उस विभाग के नाम के अंतर्गत सभी छात्रों को उनके नाम के अनुसार अवरोही क्रम में प्रदर्शित किया जाएगा

SQLite सीमा:

आप LIMIT क्लॉज़ का उपयोग करके अपनी SQL क्वेरी द्वारा लौटाई गई पंक्तियों की संख्या को सीमित कर सकते हैं। उदाहरण के लिए, LIMIT 10 आपको केवल 10 पंक्तियाँ देगा और अन्य सभी पंक्तियों को अनदेखा कर देगा।

LIMIT क्लॉज में, आप OFFSET क्लॉज का उपयोग करके किसी विशिष्ट स्थान से शुरू करके पंक्तियों की एक विशिष्ट संख्या का चयन कर सकते हैं। उदाहरण के लिए, “सीमा 4 ऑफसेट 4” पहली 4 पंक्तियों को अनदेखा कर देगा, और पांचवीं पंक्ति से शुरू करके 4 पंक्तियाँ लौटाएगा, इसलिए आपको पंक्तियाँ 5,6,7 और 8 मिलेंगी।

ध्यान दें कि OFFSET क्लॉज़ वैकल्पिक है, आप इसे इस तरह लिख सकते हैं “LIMIT 4, 4” और यह आपको सटीक परिणाम देगा।

उदाहरण:

निम्नलिखित उदाहरण में, हम क्वेरी का उपयोग करके छात्र आईडी 3 से शुरू करते हुए केवल 5 छात्रों को लौटाएंगे:

SELECT * FROM Students LIMIT 4,3;

इससे आपको पंक्ति 5 से शुरू करते हुए केवल तीन छात्र मिलेंगे। इसलिए यह आपको StudentId 5, 6, और 7 वाली पंक्तियाँ देगा:

सीमित करना और आदेश देना

डुप्लीकेट हटाना

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

उदाहरण:

निम्नलिखित क्वेरी डुप्लिकेट "विभाग नाम मान" लौटाएगी: यहां हमारे पास आईटी, भौतिकी और कला नामों के साथ डुप्लिकेट मान हैं।

SELECT d.DepartmentName
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;

इससे आपको विभाग के नाम के लिए डुप्लिकेट मान मिलेंगे:

डुप्लिकेट हटाना

ध्यान दें, विभाग के नाम के लिए डुप्लिकेट मान कैसे हैं। अब, हम उन डुप्लिकेट को हटाने और केवल अद्वितीय मान प्राप्त करने के लिए उसी क्वेरी के साथ DISTINCT कीवर्ड का उपयोग करेंगे। इस तरह:

SELECT DISTINCT d.DepartmentName
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;

इससे आपको विभाग नाम कॉलम के लिए केवल तीन अद्वितीय मान मिलेंगे:

डुप्लिकेट हटाना

कुल

SQLite समुच्चय अंतर्निहित फ़ंक्शन हैं जिन्हें परिभाषित किया गया है SQLite जो एकाधिक पंक्तियों के एकाधिक मानों को एक मान में समूहित करेगा।

यहां पर निम्नलिखित द्वारा समर्थित समुच्चय दिए गए हैं: SQLite:

SQLite AVG()

सभी x मानों का औसत लौटाया गया.

उदाहरण:

निम्नलिखित उदाहरण में हम सभी परीक्षाओं में छात्रों द्वारा प्राप्त औसत अंक प्राप्त करेंगे:

SELECT AVG(Mark) FROM Marks;

इससे आपको “18.375” का मान मिलेगा:

सकल:SQLite AVG()

ये परिणाम सभी अंक मानों के योग को उनकी गिनती से विभाजित करने पर प्राप्त होते हैं।

COUNT() – COUNT(X) या COUNT(*)

x मान के प्रकट होने की कुल संख्या लौटाता है। और यहाँ कुछ विकल्प दिए गए हैं जिनका उपयोग आप COUNT के साथ कर सकते हैं:

  • COUNT(x): केवल x मानों की गणना करता है, जहाँ x एक कॉलम नाम है। यह NULL मानों को अनदेखा कर देगा।
  • COUNT(*): सभी स्तंभों से सभी पंक्तियों की गणना करें।
  • COUNT (DISTINCT x): आप x से पहले DISTINCT कीवर्ड निर्दिष्ट कर सकते हैं जो x के विशिष्ट मानों की गणना प्राप्त करेगा।

उदाहरण

निम्नलिखित उदाहरण में, हम COUNT(DepartmentId), COUNT(*) और COUNT(DISTINCT DepartmentId) वाले विभागों की कुल संख्या प्राप्त करेंगे और देखेंगे कि वे किस प्रकार भिन्न हैं:

SELECT COUNT(DepartmentId), COUNT(DISTINCT DepartmentId), COUNT(*) FROM Students;

इससे आपको मिलेगा:

कुल: COUNT() – COUNT(X) या COUNT(*)

के रूप में निम्नानुसार:

  • COUNT(DepartmentId) आपको सभी विभाग आईडी की गिनती देगा, और यह शून्य मानों को अनदेखा कर देगा।
  • COUNT(DISTINCT DepartmentId) आपको DepartmentId के अलग-अलग मान देता है, जो केवल 3 हैं। जो विभाग के नाम के तीन अलग-अलग मान हैं। ध्यान दें कि छात्र के नाम में विभाग के नाम के 8 मान हैं। लेकिन केवल तीन अलग-अलग मान जो गणित, आईटी और भौतिकी हैं।
  • COUNT(*) छात्रों की तालिका में पंक्तियों की संख्या गिनता है जो 10 छात्रों के लिए 10 पंक्तियाँ हैं।

GROUP_CONCAT() – GROUP_CONCAT(X) या GROUP_CONCAT(X,Y)

GROUP_CONCAT एग्रीगेट फ़ंक्शन एकाधिक मानों को अल्पविराम से अलग करके एक मान में संयोजित करता है। इसमें निम्नलिखित विकल्प हैं:

  • GROUP_CONCAT(X): यह x के सभी मानों को एक स्ट्रिंग में संयोजित करेगा, जिसमें अल्पविराम “,” का उपयोग मानों के बीच विभाजक के रूप में किया जाएगा। शून्य मानों को अनदेखा किया जाएगा।
  • GROUP_CONCAT(X, Y): यह x के मानों को एक स्ट्रिंग में संयोजित करेगा, जिसमें y का मान डिफ़ॉल्ट विभाजक ',' के बजाय प्रत्येक मान के बीच विभाजक के रूप में उपयोग किया जाएगा। NULL मानों को भी अनदेखा किया जाएगा।
  • GROUP_CONCAT(DISTINCT X): यह x के सभी अलग-अलग मानों को एक स्ट्रिंग में संयोजित करेगा, जिसमें अल्पविराम “,” का उपयोग मानों के बीच विभाजक के रूप में किया जाएगा। NULL मानों को अनदेखा किया जाएगा।

GROUP_CONCAT(DepartmentName) उदाहरण

निम्नलिखित क्वेरी छात्रों और विभागों की तालिका से सभी विभाग नाम के मानों को अल्पविराम से अलग करके एक स्ट्रिंग में संयोजित करेगी। इसलिए मानों की सूची लौटाने के बजाय, प्रत्येक पंक्ति पर एक मान लौटाएगा। यह एक पंक्ति पर केवल एक मान लौटाएगा, जिसमें सभी मान अल्पविराम से अलग होंगे:

SELECT GROUP_CONCAT(d.DepartmentName)
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;

इससे आपको मिलेगा:

समुच्चय:GROUP_CONCAT() – GROUP_CONCAT(X) या GROUP_CONCAT(X,Y)

इससे आपको 8 विभागों के नाम मानों की सूची मिलेगी जो अल्पविराम से अलग करके एक स्ट्रिंग में संयोजित होंगे।

GROUP_CONCAT(DISTINCT विभागनाम) उदाहरण

निम्नलिखित क्वेरी छात्रों और विभागों तालिका से विभाग के नाम के अलग-अलग मानों को अल्पविराम से अलग करके एक स्ट्रिंग में संयोजित करेगी:

SELECT GROUP_CONCAT(DISTINCT d.DepartmentName)
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;

इससे आपको मिलेगा:

समुच्चय:GROUP_CONCAT(DISTINCT विभागनाम) उदाहरण

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

GROUP_CONCAT(DepartmentName ,'&') उदाहरण

निम्नलिखित क्वेरी छात्रों और विभागों तालिका से विभाग नाम कॉलम के सभी मानों को एक स्ट्रिंग में संयोजित करेगी, लेकिन विभाजक के रूप में अल्पविराम के बजाय '&' वर्ण का उपयोग करेगी:

SELECT GROUP_CONCAT(d.DepartmentName, '&')
FROM Students AS s
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId;

इससे आपको मिलेगा:

समुच्चय:GROUP_CONCAT(DepartmentName ,'&') उदाहरण

ध्यान दें कि मानों के बीच अंतर करने के लिए डिफ़ॉल्ट वर्ण “,” के स्थान पर वर्ण “&” का उपयोग किया गया है।

SQLite अधिकतम() और न्यूनतम()

MAX(X) आपको X मानों में से सबसे बड़ा मान लौटाता है। अगर x के सभी मान शून्य हैं, तो MAX एक NULL मान लौटाएगा। जबकि MIN(X) आपको X मानों में से सबसे छोटा मान लौटाता है। अगर X के सभी मान शून्य हैं, तो MIN एक NULL मान लौटाएगा।

उदाहरण

निम्नलिखित क्वेरी में, हम " से उच्चतम अंक और निम्नतम अंक प्राप्त करने के लिए MIN और MAX फ़ंक्शन का उपयोग करेंगे।निशान" मेज़:

SELECT MAX(Mark), MIN(Mark) FROM Marks;

इससे आपको मिलेगा:

सकल:SQLite अधिकतम() और न्यूनतम()

SQLite योग(x), कुल(x)

दोनों ही सभी x मानों का योग लौटाएंगे। लेकिन वे निम्नलिखित में भिन्न हैं:

  • यदि सभी मान शून्य हैं तो SUM शून्य लौटाएगा, लेकिन कुल 0 लौटाएगा।
  • TOTAL हमेशा फ़्लोटिंग पॉइंट मान लौटाता है। यदि सभी x मान पूर्णांक हैं, तो SUM एक पूर्णांक मान लौटाता है। हालाँकि, यदि मान पूर्णांक नहीं हैं, तो यह फ़्लोटिंग पॉइंट मान लौटाएगा।

उदाहरण

निम्नलिखित क्वेरी में हम सभी अंकों का योग प्राप्त करने के लिए SUM और कुल का उपयोग करेंगे “निशान” टेबल:

SELECT SUM(Mark), TOTAL(Mark) FROM Marks;

इससे आपको मिलेगा:

सकल:SQLite योग(x), कुल(x)

जैसा कि आप देख सकते हैं, TOTAL हमेशा एक फ़्लोटिंग पॉइंट लौटाता है। लेकिन SUM एक पूर्णांक मान लौटाता है क्योंकि “मार्क” कॉलम में मान पूर्णांक में हो सकते हैं।

SUM और TOTAL के बीच अंतर का उदाहरण:

निम्नलिखित क्वेरी में हम SUM और TOTAL के बीच अंतर दिखाएंगे जब उन्हें NULL मानों का SUM मिलेगा:

SELECT SUM(Mark), TOTAL(Mark) FROM Marks WHERE TestId = 4;

इससे आपको मिलेगा:

समुच्चय: SUM और TOTAL के बीच अंतर उदाहरण

ध्यान दें कि TestId = 4 के लिए कोई चिह्न नहीं है, इसलिए उस परीक्षण के लिए शून्य मान हैं। SUM रिक्त के रूप में शून्य मान लौटाता है, जबकि TOTAL 0 लौटाता है।

द्वारा समूह बनाएं

GROUP BY क्लॉज़ का उपयोग एक या अधिक कॉलम निर्दिष्ट करने के लिए किया जाता है जिसका उपयोग पंक्तियों को समूहों में समूहित करने के लिए किया जाएगा। समान मान वाली पंक्तियों को समूहों में एक साथ इकट्ठा (व्यवस्थित) किया जाएगा।

किसी अन्य कॉलम के लिए जो कॉलम द्वारा समूह में शामिल नहीं है, आप उसके लिए एक समग्र फ़ंक्शन का उपयोग कर सकते हैं।

उदाहरण:

निम्नलिखित प्रश्न आपको प्रत्येक विभाग में उपस्थित छात्रों की कुल संख्या बताएगा।

SELECT d.DepartmentName, COUNT(s.StudentId) AS StudentsCount
FROM Students AS s 
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId
GROUP BY d. DepartmentName;

इससे आपको मिलेगा:

समूह BY:HAVING खंड

GROUPBY DepartmentName क्लॉज सभी छात्रों को प्रत्येक विभाग के नाम के लिए एक समूह में समूहित करेगा। “विभाग” के प्रत्येक समूह के लिए, यह उस पर छात्रों की गिनती करेगा।

HAVING खंड

यदि आप GROUP BY क्लॉज द्वारा लौटाए गए समूहों को फ़िल्टर करना चाहते हैं, तो आप GROUP BY के बाद अभिव्यक्ति के साथ “HAVING” क्लॉज निर्दिष्ट कर सकते हैं। अभिव्यक्ति का उपयोग इन समूहों को फ़िल्टर करने के लिए किया जाएगा।

उदाहरण

निम्नलिखित क्वेरी में, हम उन विभागों का चयन करेंगे जिनमें केवल दो छात्र हैं:

SELECT d.DepartmentName, COUNT(s.StudentId) AS StudentsCount
FROM Students AS s 
INNER JOIN Departments AS d ON s.DepartmentId = d.DepartmentId
GROUP BY d. DepartmentName
HAVING COUNT(s.StudentId) = 2;

इससे आपको मिलेगा:

द्वारा समूह बनाएं

क्लॉज HAVING COUNT(S.StudentId) = 2 लौटाए गए समूहों को फ़िल्टर करेगा और केवल उन समूहों को लौटाएगा जिनमें ठीक दो छात्र हैं। हमारे मामले में, कला विभाग में 2 छात्र हैं, इसलिए इसे आउटपुट में प्रदर्शित किया जाता है।

SQLite क्वेरी और सबक्वेरी

किसी भी क्वेरी के अंदर, आप SELECT, INSERT, DELETE, UPDATE या किसी अन्य सबक्वेरी के अंदर किसी अन्य क्वेरी का उपयोग कर सकते हैं।

इस नेस्टेड क्वेरी को सबक्वेरी कहा जाता है। अब हम SELECT क्लॉज में सबक्वेरी का उपयोग करने के कुछ उदाहरण देखेंगे। हालाँकि, डेटा संशोधित करने वाले ट्यूटोरियल में, हम देखेंगे कि हम INSERT, DELETE और UPDATE स्टेटमेंट के साथ सबक्वेरी का उपयोग कैसे कर सकते हैं।

FROM क्लॉज़ उदाहरण में सबक्वेरी का उपयोग करना

निम्नलिखित क्वेरी में हम FROM क्लॉज़ के अंदर एक सबक्वेरी शामिल करेंगे:

SELECT
  s.StudentName, t.Mark
FROM Students AS s 
INNER JOIN
(
   SELECT StudentId, Mark
   FROM Tests AS t
   INNER JOIN Marks AS m ON t.TestId = m.TestId
)  ON s.StudentId = t.StudentId;

पूछताछ:

   SELECT StudentId, Mark
   FROM Tests AS t
   INNER JOIN Marks AS m ON t.TestId = m.TestId

उपरोक्त क्वेरी को यहाँ सबक्वेरी कहा जाता है क्योंकि यह FROM क्लॉज़ के अंदर नेस्टेड है। ध्यान दें कि हमने इसे एक उपनाम नाम “t” दिया है ताकि हम क्वेरी में इससे लौटाए गए कॉलम को संदर्भित कर सकें।

यह क्वेरी आपको देगी:

SQLite क्वेरी और सबक्वेरी: FROM क्लॉज में सबक्वेरी का उपयोग करना

तो हमारे मामले में,

  • s.StudentName मुख्य क्वेरी से चुना जाता है जो छात्रों का नाम देता है और
  • t.Mark को सबक्वेरी से चुना जाता है; जो प्रत्येक छात्र द्वारा प्राप्त अंक देता है

WHERE क्लॉज़ उदाहरण में सबक्वेरी का उपयोग करना

निम्नलिखित क्वेरी में हम WHERE क्लॉज़ में एक सबक्वेरी शामिल करेंगे:

SELECT DepartmentName
FROM Departments AS d
WHERE NOT EXISTS (SELECT DepartmentId 
                  FROM Students AS s 
                  WHERE d.DepartmentId = s.DepartmentId);

पूछताछ:

SELECT DepartmentId 
FROM Students AS s 
WHERE d.DepartmentId = s.DepartmentId

उपरोक्त क्वेरी को यहाँ सबक्वेरी कहा जाता है क्योंकि यह WHERE क्लॉज़ में नेस्टेड है। सबक्वेरी डिपार्टमेंटआईडी मान लौटाएगी जिसका उपयोग ऑपरेटर NOT EXISTS द्वारा किया जाएगा।

यह क्वेरी आपको देगी:

SQLite क्वेरी और सबक्वेरी: WHERE क्लॉज में सबक्वेरी का उपयोग करना

उपरोक्त क्वेरी में, हमने उस विभाग का चयन किया है जिसमें कोई छात्र नामांकित नहीं है। जो यहाँ पर “गणित” विभाग है।

सेट Operaयूनियन, इंटरसेक्ट

SQLite निम्नलिखित SET ऑपरेशन का समर्थन करता है:

यूनियन और यूनियन ऑल

यह एकाधिक SELECT कथनों से लौटाए गए एक या अधिक परिणाम सेट (पंक्तियों का एक समूह) को एक परिणाम सेट में संयोजित करता है।

UNION अलग-अलग मान लौटाएगा। हालाँकि, UNION ALL ऐसा नहीं करेगा और इसमें डुप्लिकेट शामिल होंगे।

ध्यान दें कि स्तंभ नाम पहले SELECT कथन में निर्दिष्ट स्तंभ नाम होगा।

यूनियन उदाहरण

निम्नलिखित उदाहरण में, हमें उसी कॉलम में students तालिका से DepartmentId की सूची और department तालिका से DepartmentId की सूची मिलेगी:

SELECT DepartmentId AS DepartmentIdUnioned FROM Students
UNION
SELECT DepartmentId FROM Departments;

इससे आपको मिलेगा:

सेट Operaयूनियन उदाहरण

क्वेरी केवल 5 पंक्तियाँ लौटाती है जो अलग-अलग डिपार्टमेंट आईडी मान हैं। पहले मान पर ध्यान दें जो शून्य मान है।

SQLite UNION ALL उदाहरण

निम्नलिखित उदाहरण में, हमें उसी कॉलम में students तालिका से DepartmentId की सूची और department तालिका से DepartmentId की सूची मिलेगी:

SELECT DepartmentId AS DepartmentIdUnioned FROM Students
UNION ALL
SELECT DepartmentId FROM Departments;

इससे आपको मिलेगा:

सेट Operaयूनियन उदाहरण

क्वेरी 14 पंक्तियाँ लौटाएगी, 10 पंक्तियाँ students टेबल से और 4 पंक्तियाँ department टेबल से। ध्यान दें कि लौटाए गए मानों में डुप्लिकेट हैं। साथ ही, ध्यान दें कि कॉलम का नाम वही था जो पहले SELECT कथन में निर्दिष्ट किया गया था।

अब, आइए देखें कि यदि हम UNION ALL को UNION से प्रतिस्थापित करें तो UNION all किस प्रकार भिन्न परिणाम देगा:

SQLite एक दूसरे को काटना

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

उदाहरण

निम्नलिखित क्वेरी में, हम DepartmentId कॉलम में Students और Departments दोनों तालिकाओं में मौजूद DepartmentId मानों का चयन करेंगे:

SELECT DepartmentId FROM Students
Intersect
SELECT DepartmentId FROM Departments;

इससे आपको मिलेगा:

सेट Operations - इंटरसेक्ट

क्वेरी केवल तीन मान 1, 2 और 3 लौटाती है। ये वे मान हैं जो दोनों तालिकाओं में मौजूद हैं।

हालाँकि, शून्य और 4 मान शामिल नहीं किए गए क्योंकि शून्य मान केवल छात्रों की तालिका में मौजूद है और विभागों की तालिका में नहीं है। और मान 4 विभागों की तालिका में मौजूद है और छात्रों की तालिका में नहीं है।

यही कारण है कि NULL और 4 दोनों मानों को नजरअंदाज कर दिया गया और लौटाए गए मानों में शामिल नहीं किया गया।

के सिवाय

मान लीजिए कि आपके पास पंक्तियों की दो सूचियाँ हैं, सूची 1 और सूची 2, और आप केवल सूची 1 से पंक्तियाँ चाहते हैं जो सूची 2 में मौजूद नहीं हैं, तो आप "EXCEPT" खंड का उपयोग कर सकते हैं। EXCEPT खंड दो सूचियों की तुलना करता है और उन पंक्तियों को लौटाता है जो सूची 1 में मौजूद हैं और सूची 2 में मौजूद नहीं हैं।

उदाहरण

निम्नलिखित क्वेरी में, हम उन DepartmentId मानों का चयन करेंगे जो विभाग तालिका में मौजूद हैं और छात्र तालिका में मौजूद नहीं हैं:

SELECT DepartmentId FROM Departments
EXCEPT
SELECT DepartmentId FROM Students;

इससे आपको मिलेगा:

सेट Operations - सिवाय

क्वेरी केवल मान 4 लौटाती है। यह एकमात्र मान है जो विभाग तालिका में मौजूद है, और छात्र तालिका में मौजूद नहीं है।

नल हैंडलिंग

"नल” मान एक विशेष मान है SQLiteइसका उपयोग किसी अज्ञात या लुप्त मान को दर्शाने के लिए किया जाता है। ध्यान दें कि शून्य मान “ से बिलकुल अलग है0” या रिक्त “” मान। क्योंकि 0 और रिक्त मान एक ज्ञात मान है, तथापि, शून्य मान अज्ञात है।

NULL मानों को विशेष प्रबंधन की आवश्यकता होती है SQLiteअब हम देखेंगे कि NULL मानों को कैसे संभालना है।

शून्य मानों की खोज करें

आप शून्य मानों को खोजने के लिए सामान्य समानता ऑपरेटर (=) का उपयोग नहीं कर सकते। उदाहरण के लिए, निम्न क्वेरी उन छात्रों की खोज करती है जिनके पास शून्य DepartmentId मान है:

SELECT * FROM Students WHERE DepartmentId = NULL;

यह क्वेरी कोई परिणाम नहीं देगी:

नल हैंडलिंग

क्योंकि NULL मान किसी अन्य मान के बराबर नहीं होता है जिसमें स्वयं शून्य मान शामिल होता है, इसीलिए इसने कोई परिणाम नहीं दिया।

  • हालाँकि, क्वेरी को काम करने के लिए, आपको इसका उपयोग करना होगा “शून्य है” शून्य मानों की खोज करने के लिए ऑपरेटर का उपयोग इस प्रकार करें:
SELECT * FROM Students WHERE DepartmentId IS NULL;

इससे आपको मिलेगा:

नल हैंडलिंग

क्वेरी उन छात्रों को लौटाएगी जिनका DepartmentId मान शून्य है।

  • यदि आप उन मानों को प्राप्त करना चाहते हैं जो शून्य नहीं हैं, तो आपको “निरर्थक नहीं है” ऑपरेटर का उपयोग इस प्रकार करें:
SELECT * FROM Students WHERE DepartmentId IS NOT NULL;

इससे आपको मिलेगा:

नल हैंडलिंग

क्वेरी उन छात्रों को लौटाएगी जिनके पास NULL DepartmentId मान नहीं है।

सशर्त परिणाम

यदि आपके पास मानों की एक सूची है और आप कुछ शर्तों के आधार पर उनमें से किसी एक का चयन करना चाहते हैं, तो उसके लिए उस विशेष मान के लिए शर्त सत्य होनी चाहिए।

CASE अभिव्यक्ति सभी मानों के लिए शर्तों की इन सूची का मूल्यांकन करेगी। यदि शर्त सत्य है, तो यह उस मान को लौटाएगा।

उदाहरण के लिए, यदि आपके पास एक कॉलम “ग्रेड” है और आप ग्रेड मान के आधार पर निम्नलिखित पाठ मान चुनना चाहते हैं:

– “उत्कृष्ट” यदि ग्रेड 85 से अधिक है।

– “बहुत अच्छा” यदि ग्रेड 70 और 85 के बीच है।

– “अच्छा” यदि ग्रेड 60 और 70 के बीच है।

फिर आप ऐसा करने के लिए CASE अभिव्यक्ति का उपयोग कर सकते हैं।

इसका उपयोग SELECT क्लॉज में कुछ तर्क को परिभाषित करने के लिए किया जा सकता है ताकि आप उदाहरण के लिए if स्टेटमेंट जैसी कुछ शर्तों के आधार पर कुछ परिणामों का चयन कर सकें।

CASE ऑपरेटर को निम्नलिखित विभिन्न सिंटैक्स के साथ परिभाषित किया जा सकता है:

  1. आप विभिन्न स्थितियों का उपयोग कर सकते हैं:
CASE 
  WHEN condition1 THEN result1
  WHEN condition2 THEN result2
  WHEN condition3 THEN result3
  …
  ELSE resultn
END
  1. या, आप केवल एक अभिव्यक्ति का उपयोग कर सकते हैं और चुनने के लिए विभिन्न संभावित मान रख सकते हैं:
CASE expression
  WHEN value1 THEN result1
  WHEN value2 THEN result2
  WHEN value3 THEN result3
  …
  ELSE restuln 
END

ध्यान रखें कि ELSE खंड वैकल्पिक है।

उदाहरण

निम्नलिखित उदाहरण में, हम इसका उपयोग करेंगे CASE अभिव्यक्ति के साथ नल 'कोई विभाग नहीं' पाठ प्रदर्शित करने के लिए छात्र तालिका में विभाग आईडी कॉलम में मान को निम्न प्रकार से भरें:

SELECT 
  StudentName,
  CASE 
    WHEN DepartmentId IS NULL THEN 'No Department'
    ELSE DepartmentId 
  END AS DepartmentId
FROM Students;
  • CASE ऑपरेटर DepartmentId का मान जांचेगा कि वह शून्य है या नहीं।
  • यदि यह NULL मान है, तो यह DepartmentId मान के स्थान पर शाब्दिक मान 'No Department' का चयन करेगा।
  • यदि शून्य मान नहीं है, तो यह DepartmentId कॉलम का मान चुनेगा.

इससे आपको नीचे दिखाए अनुसार आउटपुट मिलेगा:

सशर्त परिणाम

सामान्य तालिका अभिव्यक्ति

सामान्य तालिका अभिव्यक्तियाँ (CTE) उपक्वेरी होती हैं जिन्हें SQL कथन के अंदर दिए गए नाम से परिभाषित किया जाता है।

सबक्वेरीज़ की तुलना में इसका एक फायदा यह है कि इसे SQL स्टेटमेंट से अलग परिभाषित किया जाता है और इससे क्वेरीज़ को पढ़ना, बनाए रखना और समझना आसान हो जाता है।

एक सामान्य तालिका अभिव्यक्ति को SELECT कथन के सामने WITH खंड रखकर निम्नानुसार परिभाषित किया जा सकता है:

WITH CTEname
AS
(
   SELECT statement
)
SELECT, UPDATE, INSERT, or update statement here FROM CTE

"सीटीईनाम” कोई भी नाम है जिसे आप CTE के लिए दे सकते हैं, आप इसका उपयोग बाद में इसे संदर्भित करने के लिए कर सकते हैं। ध्यान दें कि, आप CTE पर SELECT, UPDATE, INSERT या DELETE कथन परिभाषित कर सकते हैं

अब, आइए एक उदाहरण देखें कि SELECT क्लॉज में CTE का उपयोग कैसे किया जाता है।

उदाहरण

निम्नलिखित उदाहरण में, हम SELECT कथन से CTE परिभाषित करेंगे, और फिर हम बाद में इसे किसी अन्य क्वेरी पर उपयोग करेंगे:

WITH AllDepartments
AS
(
  SELECT DepartmentId, DepartmentName
  FROM Departments
)
SELECT 
  s.StudentId,
  s.StudentName,
  a.DepartmentName
FROM Students AS s
INNER JOIN AllDepartments AS a ON s.DepartmentId = a.DepartmentId;

इस क्वेरी में, हमने एक CTE को परिभाषित किया और इसे नाम दिया “सभी विभाग“. यह CTE एक SELECT क्वेरी से परिभाषित किया गया था:

SELECT DepartmentId, DepartmentName
  FROM Departments

फिर जब हमने CTE को परिभाषित कर लिया तो हमने इसका प्रयोग SELECT क्वेरी में किया जो इसके बाद आती है।

ध्यान दें कि, कॉमन टेबल एक्सप्रेशन क्वेरी के आउटपुट को प्रभावित नहीं करते हैं। यह एक तार्किक दृश्य या सबक्वेरी को परिभाषित करने का एक तरीका है ताकि उन्हें उसी क्वेरी में पुनः उपयोग किया जा सके। कॉमन टेबल एक्सप्रेशन एक वैरिएबल की तरह होते हैं जिसे आप घोषित करते हैं, और इसे सबक्वेरी के रूप में पुनः उपयोग करते हैं। केवल SELECT कथन क्वेरी के आउटपुट को प्रभावित करता है।

यह क्वेरी आपको देगी:

सामान्य तालिका अभिव्यक्ति

उन्नत प्रश्न

उन्नत क्वेरीज़ वे क्वेरीज़ होती हैं जिनमें जटिल जॉइन, सबक्वेरीज़ और कुछ एग्रीगेट्स होते हैं। अगले भाग में हम उन्नत क्वेरी का एक उदाहरण देखेंगे:

हम कहाँ से प्राप्त करते हैं,

  • प्रत्येक विभाग के सभी छात्रों के साथ विभाग के नाम
  • छात्रों का नाम अल्पविराम से अलग करके
  • कम से कम तीन छात्रों वाले विभाग को दर्शाना
SELECT 
  d.DepartmentName,
  COUNT(s.StudentId) StudentsCount,
  GROUP_CONCAT(StudentName) AS Students
FROM Departments AS d 
INNER JOIN Students AS s ON s.DepartmentId = d.DepartmentId
GROUP BY d.DepartmentName
HAVING COUNT(s.StudentId) >= 3;

हमने एक जोड़ दिया शामिल हों डिपार्टमेंट्स टेबल से डिपार्टमेंटनाम प्राप्त करने के लिए क्लॉज। उसके बाद हमने दो एग्रीगेट फ़ंक्शन के साथ एक GROUP BY क्लॉज जोड़ा:

  • प्रत्येक विभाग समूह के छात्रों की गिनती करने के लिए “COUNT” का प्रयोग करें।
  • GROUP_CONCAT प्रत्येक समूह के छात्रों को एक स्ट्रिंग में अल्पविराम से अलग करके संयोजित करने के लिए।
  • GROUP BY के बाद, हमने विभागों को फ़िल्टर करने के लिए HAVING क्लॉज़ का उपयोग किया और केवल उन विभागों का चयन किया जिनमें कम से कम 3 छात्र हों।

परिणाम निम्नलिखित होगा:

उन्नत प्रश्न

सारांश

यह लेखन का एक परिचय था SQLite क्वेरीज़ और डेटाबेस क्वेरी करने की मूल बातें और आप कैसे लौटाए गए डेटा को फ़िल्टर कर सकते हैं। अब आप अपना खुद का लिख ​​सकते हैं SQLite प्रश्नों।