वितरित DBMS - डेटाबेस नियंत्रण
डेटाबेस नियंत्रण नियमों को लागू करने के कार्य को संदर्भित करता है ताकि प्रामाणिक उपयोगकर्ताओं और डेटाबेस के अनुप्रयोगों को सही डेटा प्रदान किया जा सके। उपयोगकर्ताओं को सही डेटा उपलब्ध होने के लिए, सभी डेटा को डेटाबेस में परिभाषित अखंडता बाधाओं के अनुरूप होना चाहिए। इसके अलावा, डेटा को अनधिकृत उपयोगकर्ताओं से दूर रखा जाना चाहिए ताकि डेटाबेस की सुरक्षा और गोपनीयता बनाए रखी जा सके। डेटाबेस कंट्रोल डेटाबेस एडमिनिस्ट्रेटर (DBA) के प्राथमिक कार्यों में से एक है।
डेटाबेस नियंत्रण के तीन आयाम हैं -
- Authentication
- पहुंच अधिकार
- ईमानदारी की कमी
प्रमाणीकरण
एक वितरित डेटाबेस प्रणाली में, प्रमाणीकरण वह प्रक्रिया है जिसके माध्यम से केवल वैध उपयोगकर्ता डेटा संसाधनों तक पहुंच प्राप्त कर सकते हैं।
प्रमाणीकरण को दो स्तरों में लागू किया जा सकता है -
Controlling Access to Client Computer- इस स्तर पर, उपयोगकर्ता का डेटाबेस सर्वर के लिए यूजर-इंटरफेस प्रदान करने वाले क्लाइंट कंप्यूटर पर लॉगिन करते समय प्रतिबंधित है। सबसे आम तरीका एक उपयोगकर्ता नाम / पासवर्ड संयोजन है। हालांकि, उच्च सुरक्षा डेटा के लिए बायोमेट्रिक प्रमाणीकरण जैसे अधिक परिष्कृत तरीकों का उपयोग किया जा सकता है।
Controlling Access to the Database Software- इस स्तर पर, डेटाबेस सॉफ्टवेयर / व्यवस्थापक उपयोगकर्ता को कुछ क्रेडेंशियल्स प्रदान करता है। उपयोगकर्ता इन क्रेडेंशियल्स का उपयोग करके डेटाबेस तक पहुंच प्राप्त करता है। डेटाबेस सर्वर के भीतर एक लॉगिन खाता बनाने के लिए तरीकों में से एक है।
पहुंच अधिकार
उपयोगकर्ता के उपयोग के अधिकार उन विशेषाधिकारों को संदर्भित करते हैं जो उपयोगकर्ता को डीबीएमएस परिचालनों के बारे में दिए जाते हैं जैसे कि तालिका बनाने के अधिकार, तालिका को ड्रॉप करना, तालिका में टेबल जोड़ना या हटाना / अपडेट करना या तालिका पर क्वेरी करना।
वितरित वातावरण में, चूंकि बड़ी संख्या में टेबल हैं और अभी भी बड़ी संख्या में उपयोगकर्ता हैं, इसलिए उपयोगकर्ताओं के लिए व्यक्तिगत पहुँच अधिकार प्रदान करना संभव नहीं है। तो, DDBMS कुछ भूमिकाओं को परिभाषित करता है। एक भूमिका एक डेटाबेस सिस्टम के भीतर कुछ विशेषाधिकारों के साथ एक निर्माण है। एक बार विभिन्न भूमिकाओं को परिभाषित करने के बाद, व्यक्तिगत उपयोगकर्ताओं को इनमें से एक भूमिका सौंपी जाती है। अक्सर भूमिका की पदानुक्रम को संगठन के अधिकार और जिम्मेदारी के पदानुक्रम के अनुसार परिभाषित किया जाता है।
उदाहरण के लिए, निम्नलिखित एसक्यूएल स्टेटमेंट एक भूमिका "एकाउंटेंट" बनाते हैं और फिर उपयोगकर्ता "एबीसी" को यह भूमिका सौंपते हैं।
CREATE ROLE ACCOUNTANT;
GRANT SELECT, INSERT, UPDATE ON EMP_SAL TO ACCOUNTANT;
GRANT INSERT, UPDATE, DELETE ON TENDER TO ACCOUNTANT;
GRANT INSERT, SELECT ON EXPENSE TO ACCOUNTANT;
COMMIT;
GRANT ACCOUNTANT TO ABC;
COMMIT;
शब्दार्थ अखंडता नियंत्रण
शब्दार्थ अखंडता नियंत्रण डेटाबेस प्रणाली की अखंडता बाधाओं को परिभाषित करता है और लागू करता है।
अखंडता बाधाएं इस प्रकार हैं -
- डेटा प्रकार अखंडता बाधा
- इकाई अखंडता बाधा
- अधिमान्य अखंडता बाधा
डेटा प्रकार अखंडता बाधा
डेटा प्रकार की बाधाएँ मानों की श्रेणी और उन प्रकारों के संचालन को प्रतिबंधित करती हैं जिन्हें निर्दिष्ट डेटा प्रकार के साथ फ़ील्ड पर लागू किया जा सकता है।
उदाहरण के लिए, आइए विचार करें कि एक तालिका "HOSTEL" के तीन क्षेत्र हैं - छात्रावास संख्या, छात्रावास का नाम और क्षमता। हॉस्टल नंबर कैपिटल लेटर "H" से शुरू होना चाहिए और NULL नहीं हो सकता है, और क्षमता 150 से अधिक नहीं होनी चाहिए। निम्न SQL कमांड का उपयोग डेटा परिभाषा के लिए किया जा सकता है -
CREATE TABLE HOSTEL (
H_NO VARCHAR2(5) NOT NULL,
H_NAME VARCHAR2(15),
CAPACITY INTEGER,
CHECK ( H_NO LIKE 'H%'),
CHECK ( CAPACITY <= 150)
);
इकाई अखंडता नियंत्रण
इकाई अखंडता नियंत्रण नियमों को लागू करता है ताकि प्रत्येक ट्यूपल को अन्य ट्यूपलों से विशिष्ट रूप से पहचाना जा सके। इसके लिए एक प्राथमिक कुंजी परिभाषित की गई है। एक प्राथमिक कुंजी न्यूनतम फ़ील्ड्स का एक सेट है जो विशिष्ट रूप से टपल की पहचान कर सकती है। इकाई अखंडता बाधा बताती है कि तालिका में कोई भी दो ट्यूपल प्राथमिक कुंजी के लिए समान मान नहीं रख सकते हैं और यह कि कोई भी फ़ील्ड जो प्राथमिक कुंजी का एक हिस्सा नहीं है, का पूर्ण मान हो सकता है।
उदाहरण के लिए, उपरोक्त हॉस्टल तालिका में, होस्टल नंबर को निम्न एसक्यूएल स्टेटमेंट (चेक को नजरअंदाज करते हुए) के माध्यम से प्राथमिक कुंजी के रूप में सौंपा जा सकता है।
CREATE TABLE HOSTEL (
H_NO VARCHAR2(5) PRIMARY KEY,
H_NAME VARCHAR2(15),
CAPACITY INTEGER
);
रेफ़रेंशियल इंटिग्रिटी कंस्ट्रक्शन
रेफ़रेंशियल अखंडता बाधा विदेशी कुंजी के नियमों का पालन करती है। एक विदेशी कुंजी एक डेटा तालिका में एक फ़ील्ड है जो संबंधित तालिका की प्राथमिक कुंजी है। संदर्भात्मक अखंडता की कमी इस नियम का पालन करती है कि विदेशी कुंजी फ़ील्ड का मान या तो संदर्भित तालिका की प्राथमिक कुंजी के मूल्यों के बीच होना चाहिए या पूरी तरह से NULL होना चाहिए।
उदाहरण के लिए, आइए हम एक छात्र तालिका पर विचार करें जहां एक छात्र एक छात्रावास में रहने का विकल्प चुन सकता है। इसे शामिल करने के लिए, छात्रावास की मेज की प्राथमिक कुंजी को छात्र तालिका में एक विदेशी कुंजी के रूप में शामिल किया जाना चाहिए। निम्न SQL कथन इसमें सम्मिलित है -
CREATE TABLE STUDENT (
S_ROLL INTEGER PRIMARY KEY,
S_NAME VARCHAR2(25) NOT NULL,
S_COURSE VARCHAR2(10),
S_HOSTEL VARCHAR2(5) REFERENCES HOSTEL
);