अध्याय 9: दृश्य (Views)

अध्याय 9: दृश्य (Views)

दृश्य (Views) SQL में एक शक्तिशाली और उपयोगी सुविधा है, जो हमें जटिल क्वेरीज के परिणामों को एक वर्चुअल टेबल के रूप में संग्रहीत करने की अनुमति देती है। यह वर्चुअल टेबल किसी भी समय वास्तविक टेबल के डेटा को प्रदर्शित कर सकती है, जिससे डेटा रिट्रीवल और प्रबंधन अधिक सरल और प्रभावी हो जाता है। दृश्य का उपयोग करते हुए, हम जटिल क्वेरीज को सरल बना सकते हैं, डेटा सुरक्षा को बढ़ा सकते हैं, और कोड को पुनः उपयोग कर सकते हैं। इस अध्याय में, हम दृश्य के निर्माण, उपयोग, और प्रबंधन के विभिन्न पहलुओं को विस्तार से समझेंगे। इस अध्याय के अंत तक, आप दृश्य की अवधारणा और उसके विभिन्न उपयोग मामलों को समझेंगे, जिससे आप अपने डेटाबेस एप्लिकेशन में दृश्य का प्रभावी ढंग से उपयोग कर सकेंगे।

दृश्य परिचय: दृश्य क्या हैं और उनका उपयोग

दृश्य (Views) SQL में एक महत्वपूर्ण सुविधा है जो हमें जटिल क्वेरीज के परिणामों को एक वर्चुअल टेबल के रूप में संग्रहीत करने की अनुमति देती है। दृश्य वास्तव में डेटाबेस में मौजूद नहीं होते; वे केवल एक संरचना होते हैं जो क्वेरी के परिणामों को स्टोर करते हैं। जब भी दृश्य का उपयोग किया जाता है, तो वह क्वेरी वास्तविक समय में निष्पादित होती है और परिणाम प्रदर्शित होते हैं।

दृश्य क्या हैं? (What are Views?)

दृश्य एक वर्चुअल टेबल है जो एक या अधिक टेबल्स से डेटा को प्रस्तुत करती है। यह डेटा को संग्रहीत नहीं करता, बल्कि डेटा को संगठित और प्रदर्शित करने का एक तरीका प्रदान करता है। दृश्य का उपयोग करके, आप जटिल SQL क्वेरीज को सरल बना सकते हैं और उन्हें बार-बार उपयोग कर सकते हैं।

उदाहरण (Example): मान लीजिए हमारे पास दो टेबल्स हैं: students और classes। हम एक दृश्य बना सकते हैं जो इन दोनों टेबल्स को जोड़ता है और छात्रों के नाम और उनकी कक्षाओं के नाम प्रदर्शित करता है।

CREATE VIEW student_classes AS
SELECT students.name, classes.class_name
FROM students
JOIN classes ON students.class_id = classes.id;

अब, हम इस दृश्य का उपयोग करके डेटा को आसानी से रिट्रीव कर सकते हैं:

SELECT * FROM student_classes;

दृश्य का उपयोग (Uses of Views)

  1. डेटा की सरलीकरण (Simplification of Data):
    • जटिल क्वेरीज को दृश्य में बदलकर, आप उन क्वेरीज को बार-बार उपयोग कर सकते हैं, जिससे कोड सरल और प्रबंधनीय बनता है।
  2. डेटा सुरक्षा (Data Security):
    • दृश्य का उपयोग संवेदनशील डेटा को छिपाने के लिए किया जा सकता है। आप केवल आवश्यक कॉलम्स को दृश्य में शामिल कर सकते हैं और अन्य कॉलम्स को छिपा सकते हैं।
  3. डेटा का अद्यतन (Data Updation):
    • दृश्य का उपयोग करके आप डेटा को अद्यतन कर सकते हैं। कुछ दृश्यों को अद्यतनीय (updatable) बनाया जा सकता है, जिससे आप मूल टेबल्स में डेटा को संशोधित कर सकते हैं।
  4. कोड का पुनः उपयोग (Code Reusability):
    • दृश्य का उपयोग करके आप जटिल क्वेरीज को एक बार लिखकर बार-बार उपयोग कर सकते हैं, जिससे कोड का पुनः उपयोग बढ़ता है।
  5. डेटा का अस्थायी संग्रहण (Temporary Data Storage):
    • दृश्य का उपयोग अस्थायी डेटा संग्रहण के रूप में किया जा सकता है, जहां आप क्वेरी के परिणामों को अस्थायी रूप से स्टोर कर सकते हैं।

दृश्य के लाभ (Benefits of Views)

  • सरलीकरण (Simplification): जटिल SQL क्वेरीज को सरल बनाना।
  • सुरक्षा (Security): संवेदनशील डेटा को छिपाना।
  • पुनः उपयोग (Reusability): क्वेरीज को बार-बार उपयोग करने की क्षमता।
  • प्रबंधन (Manageability): डेटा को व्यवस्थित और प्रबंधित करना आसान बनाना।

दृश्य के नुकसान (Drawbacks of Views)

  • प्रदर्शन (Performance): जटिल दृश्य कभी-कभी क्वेरी प्रदर्शन को धीमा कर सकते हैं, विशेष रूप से जब दृश्य में कई टेबल्स शामिल होती हैं।
  • सीमितता (Limitations): सभी दृश्य अद्यतनीय नहीं होते, और कुछ दृश्यों में डेटा को संशोधित करना संभव नहीं होता।

दृश्य बनाना और हटाना (Creating and Dropping Views)

दृश्य बनाना (Creating a View):

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

उदाहरण (Example):

CREATE VIEW high_scorers AS
SELECT name, score
FROM students
WHERE score > 90;

दृश्य हटाना (Dropping a View):

DROP VIEW view_name;

उदाहरण (Example):

DROP VIEW high_scorers;

दृश्य बनाना: सरल और जटिल दृश्य बनाना

दृश्य (Views) बनाना SQL में एक उपयोगी प्रक्रिया है, जो हमें जटिल क्वेरीज को एक वर्चुअल टेबल के रूप में संग्रहीत करने और पुनः उपयोग करने की अनुमति देती है। इस सेक्शन में, हम सरल (Simple) और जटिल (Complex) दृश्य बनाने की प्रक्रिया को विस्तार से समझेंगे।

सरल दृश्य बनाना (Creating Simple Views)

सरल दृश्य एक या दो टेबल्स पर आधारित होते हैं और एक साधारण SELECT स्टेटमेंट का उपयोग करके बनाए जाते हैं।

सिंटैक्स (Syntax):

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

उदाहरण (Example): मान लीजिए हमारे पास एक students टेबल है और हम एक सरल दृश्य बनाना चाहते हैं जो उन छात्रों के नाम और आयु को दिखाता है जिनकी आयु 18 से अधिक है।

CREATE VIEW adult_students AS
SELECT name, age
FROM students
WHERE age > 18;

अब, हम इस दृश्य का उपयोग करके डेटा को आसानी से रिट्रीव कर सकते हैं:

SELECT * FROM adult_students;

जटिल दृश्य बनाना (Creating Complex Views)

जटिल दृश्य एक से अधिक टेबल्स पर आधारित होते हैं और JOIN, उप-चयन (subqueries) और अन्य उन्नत तकनीकों का उपयोग करके बनाए जाते हैं।

सिंटैक्स (Syntax):

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table1
JOIN table2 ON table1.common_column = table2.common_column
WHERE condition;

उदाहरण (Example): मान लीजिए हमारे पास दो टेबल्स हैं: students और classes। हम एक जटिल दृश्य बनाना चाहते हैं जो छात्रों के नाम और उनकी कक्षाओं के नाम को दिखाता है।

CREATE VIEW student_classes AS
SELECT students.name, classes.class_name
FROM students
JOIN classes ON students.class_id = classes.id;

अब, हम इस दृश्य का उपयोग करके डेटा को आसानी से रिट्रीव कर सकते हैं:

SELECT * FROM student_classes;

उप-चयन के साथ जटिल दृश्य (Complex Views with Subqueries)

जटिल दृश्य में उप-चयन का भी उपयोग किया जा सकता है। यह तकनीक हमें और भी विशिष्ट और अनुकूलित दृश्य बनाने की अनुमति देती है।

उदाहरण (Example): मान लीजिए हम एक दृश्य बनाना चाहते हैं जो उन छात्रों के नाम और औसत अंक (average score) को दिखाता है जिन्होंने अपनी कक्षा के औसत से अधिक अंक प्राप्त किए हैं।

CREATE VIEW top_students AS
SELECT name, score
FROM students
WHERE score > (SELECT AVG(score) FROM students);


Index