SQLite - बाधाओं

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

बाधाएं स्तंभ स्तर या तालिका स्तर हो सकती हैं। स्तंभ स्तर की बाधाओं को केवल एक स्तंभ पर लागू किया जाता है, जबकि तालिका स्तर की बाधाओं को संपूर्ण तालिका पर लागू किया जाता है।

आमतौर पर SQLite में उपलब्ध बाधाओं का उपयोग किया जाता है।

  • NOT NULL Constraint - सुनिश्चित करता है कि एक कॉलम में NULL मान नहीं हो सकता है।

  • DEFAULT Constraint - जब कोई भी निर्दिष्ट न हो, तो कॉलम के लिए एक डिफ़ॉल्ट मान प्रदान करता है।

  • UNIQUE Constraint - सुनिश्चित करता है कि एक कॉलम के सभी मूल्य अलग-अलग हैं।

  • PRIMARY Key - विशिष्ट रूप से डेटाबेस तालिका में प्रत्येक पंक्ति / रिकॉर्ड की पहचान करता है।

  • CHECK Constraint - सुनिश्चित करता है कि एक कॉलम के सभी मान कुछ शर्तों को पूरा करते हैं।

पूर्ण बाधा नहीं

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

NULL कोई डेटा नहीं के समान नहीं है, बल्कि, यह अज्ञात डेटा का प्रतिनिधित्व करता है।

उदाहरण

उदाहरण के लिए, निम्नलिखित SQLite स्टेटमेंट कंपनी नामक एक नई तालिका बनाता है और इसमें पांच कॉलम जोड़ता है, जिनमें से तीन, ID और NAME और AGE, NULL को स्वीकार नहीं करने के लिए निर्दिष्ट करता है।

CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

बाधा बाधा

DEFAULT बाधा स्तंभ के लिए एक डिफ़ॉल्ट मान प्रदान करती है जब INSERT INTO कथन विशिष्ट मूल्य प्रदान नहीं करता है।

उदाहरण

उदाहरण के लिए, निम्न SQLite कथन कंपनी नामक एक नई तालिका बनाता है और पांच कॉलम जोड़ता है। यहां, सैलेरी कॉलम को डिफ़ॉल्ट रूप से 5000.00 पर सेट किया जाता है, इस प्रकार INSERT INTO स्टेटमेंट इस कॉलम के लिए मान प्रदान नहीं करता है, तब डिफ़ॉल्ट रूप से यह कॉलम 5000.00 पर सेट हो जाएगा।

CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL    DEFAULT 50000.00
);

विशेष बाधा

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

उदाहरण

उदाहरण के लिए, निम्न SQLite कथन कंपनी नामक एक नई तालिका बनाता है और पांच कॉलम जोड़ता है। यहां, AGE कॉलम UNIQUE पर सेट किया गया है, ताकि आपके पास एक ही उम्र के साथ दो रिकॉर्ड न हों -

CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL UNIQUE,
   ADDRESS        CHAR(50),
   SALARY         REAL    DEFAULT 50000.00
);

प्राथमिक कुंजी बाधा

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

हम उन्हें तालिका पंक्तियों को संदर्भित करने के लिए उपयोग करते हैं। प्राथमिक कुंजी अन्य तालिकाओं में विदेशी कुंजी बन जाती है, जब तालिकाओं के बीच संबंध बनाते हैं। 'लंबे समय तक कोडिंग ओवरसाइट' के कारण, प्राथमिक कुंजी SQLite में NULL हो सकती है। अन्य डेटाबेस के साथ ऐसा नहीं है।

एक प्राथमिक कुंजी एक तालिका में एक फ़ील्ड होती है जो डेटाबेस तालिका में प्रत्येक पंक्तियों / रिकॉर्ड की विशिष्ट पहचान करती है। प्राथमिक कुंजी में अनन्य मान होना चाहिए। प्राथमिक कुंजी कॉलम में NULL मान नहीं हो सकते।

एक तालिका में केवल एक प्राथमिक कुंजी हो सकती है, जिसमें एकल या एकाधिक फ़ील्ड शामिल हो सकते हैं। जब कई क्षेत्रों को प्राथमिक कुंजी के रूप में उपयोग किया जाता है, तो उन्हें ए कहा जाता हैcomposite key

यदि किसी तालिका में किसी भी फ़ील्ड पर कोई प्राथमिक कुंजी परिभाषित की गई है, तो आपके पास उस फ़ील्ड (ओं) के समान मूल्य वाले दो रिकॉर्ड नहीं हो सकते हैं।

उदाहरण

आपने पहले ही ऊपर विभिन्न उदाहरण देखे हैं जहां हमने प्राथमिक कुंजी के रूप में आईडी के साथ कंपनी तालिका बनाई है।

CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

चेक बाधा

CHECK बाधा रिकॉर्ड में दर्ज किए जा रहे मूल्य की जांच करने के लिए एक शर्त को सक्षम करता है। यदि स्थिति झूठी का मूल्यांकन करती है, तो रिकॉर्ड बाधा का उल्लंघन करता है और तालिका में दर्ज नहीं किया जाता है।

उदाहरण

उदाहरण के लिए, निम्न SQLite कंपनी नामक एक नई तालिका बनाता है और पांच कॉलम जोड़ता है। यहां, हम SALARY कॉलम के साथ एक CHECK जोड़ते हैं, ताकि आपके पास कोई SALARY Zero न हो।

CREATE TABLE COMPANY3(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL    CHECK(SALARY > 0)
);

गिरती हुई बाधा

SQLite सीमित तालिका के सीमित उपसमूह का समर्थन करता है। SQLite में ALTER TABLE कमांड उपयोगकर्ता को किसी तालिका का नाम बदलने या किसी मौजूदा तालिका में एक नया कॉलम जोड़ने की अनुमति देता है। एक स्तंभ का नाम बदलना, एक स्तंभ को हटाना, या एक तालिका से बाधाओं को जोड़ना या निकालना संभव नहीं है।