DB2 - स्कीमा

यह अध्याय स्कीमा की अवधारणा का परिचय और वर्णन करता है।

परिचय

एक स्कीमा डेटाबेस में तार्किक रूप से वर्गीकृत नामित वस्तुओं का एक संग्रह है।

डेटाबेस में, आप एक ही नाम के साथ कई डेटाबेस ऑब्जेक्ट नहीं बना सकते हैं। ऐसा करने के लिए, स्कीमा एक समूह वातावरण प्रदान करता है। आप एक डेटाबेस में कई स्कीमा बना सकते हैं और विभिन्न स्कीमा समूहों के साथ एक ही नाम से कई डेटाबेस ऑब्जेक्ट बना सकते हैं।

एक स्कीमा में टेबल, फ़ंक्शंस, इंडेक्स, टेबलस्पेस, प्रक्रियाएं, ट्रिगर आदि हो सकते हैं। उदाहरण के लिए, आप एक "कर्मचारी" डेटाबेस के लिए "प्रोफेशनल" और "पर्सनल" नाम से दो अलग-अलग स्कीमा बनाते हैं। एक ही नाम "कर्मचारी" के साथ दो अलग-अलग तालिकाओं को बनाना संभव है। इस वातावरण में, एक तालिका में व्यावसायिक जानकारी है और दूसरे में कर्मचारी की व्यक्तिगत जानकारी है। एक ही नाम के साथ दो तालिकाओं के बावजूद, उनके पास दो अलग-अलग स्कीमा हैं "व्यक्तिगत" और "पेशेवर"। इसलिए, उपयोगकर्ता किसी भी समस्या का सामना किए बिना दोनों के साथ काम कर सकता है। तालिकाओं के नामकरण में बाधाएं आने पर यह सुविधा उपयोगी है।

चलिए स्कीमा से संबंधित कुछ कमांड देखते हैं:

वर्तमान में सक्रिय स्कीमा प्राप्त करना

Syntax:

db2 get schema

Example: [वर्तमान डेटाबेस स्कीमा प्राप्त करने के लिए]

db2 get schema

वर्तमान वातावरण के लिए एक और स्कीमा सेट करना

Syntax:

db2 set schema=<schema_name>

Example: [वर्तमान उदाहरण पर्यावरण के लिए 'स्कीमा 1' की व्यवस्था करना]

db2 set schema=schema1

एक नई स्कीमा बनाना

Syntax: [अधिकृत यूजर आईडी के साथ एक नया स्कीमा बनाने के लिए]

db2 create schema <schema_name> authroization <inst_user>

Example: ['Db2inst2' के साथ अधिकृत "स्कीमा 1" स्कीमा बनाने के लिए]

db2 create schema schema1 authorization db2inst2

व्यायाम

आइए एक ही नाम से दो अलग-अलग टेबल बनाएं लेकिन दो अलग-अलग स्कीमा। यहां, आप दो अलग-अलग स्कीमाओं के साथ कर्मचारी तालिका बनाते हैं, एक व्यक्तिगत के लिए और दूसरी पेशेवर जानकारी के लिए।

Step 1: दो स्कीमा बनाएं।

Schema 1: [पेशेवर नाम के स्कीमा बनाने के लिए]

db2 create schema professional authorization db2inst2

Schema 2: [व्यक्तिगत नाम से स्कीमा बनाने के लिए]

db2 create schema personal authorization db2inst2

Step 2: कर्मचारी विवरण के लिए समान नाम वाली दो तालिकाएँ बनाएँ

Table1: पेशेवर। कर्मचारी

[स्कीमा नाम 'पेशेवर' का उपयोग करके डेटाबेस में एक नई तालिका 'कर्मचारी' बनाने के लिए]

db2 create table professional.employee(id number, name 
varchar(20), profession varchar(20), join_date date, 
salary number);

Table2: व्यक्तिगत। कर्मचारी

[एक ही डेटाबेस में एक नया टेबल 'कर्मचारी' बनाने के लिए, स्कीमा नाम 'व्यक्तिगत' के साथ]

db2 create table personal.employee(id number, name 
varchar(20), d_birth date, phone bigint, address 
varchar(200));

इन चरणों को निष्पादित करने के बाद, आपको एक ही नाम 'कर्मचारी' के साथ दो टेबल मिलते हैं, दो अलग-अलग स्कीमा के साथ।