OOAD - कार्यान्वयन रणनीतियाँ
ऑब्जेक्ट-ओरिएंटेड डिज़ाइन को लागू करना आमतौर पर एक मानक ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग लैंग्वेज (OOPL) का उपयोग करना या ऑब्जेक्ट डिज़ाइन को डेटाबेस में मैप करना शामिल है। ज्यादातर मामलों में, इसमें दोनों शामिल हैं।
प्रोग्रामिंग भाषाओं का उपयोग करके कार्यान्वयन
आमतौर पर, ऑब्जेक्ट डिज़ाइन को कोड में बदलने का कार्य एक सीधी प्रक्रिया है। C ++, Java, Smalltalk, C # और Python जैसी कोई भी ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज में क्लासेस का प्रतिनिधित्व करने का प्रावधान शामिल है। इस अध्याय में, हम C ++ का उपयोग करते हुए अवधारणा का उदाहरण देते हैं।
निम्न आंकड़ा वर्ग सर्किल का प्रतिनिधित्व दर्शाता है C ++ का उपयोग करते हुए।
संघों को लागू करना
अधिकांश प्रोग्रामिंग भाषाएं संघों को सीधे लागू करने के लिए निर्माण प्रदान नहीं करती हैं। इसलिए संघों को लागू करने के कार्य पर काफी विचार करने की आवश्यकता है।
एसोसिएशन या तो यूनिडायरेक्शनल या बिडायरेक्शनल हो सकती हैं। इसके अलावा, प्रत्येक एसोसिएशन एक-से-एक, एक-से-कई, या कई-से-कई हो सकती है।
अप्रत्यक्ष संघ
यूनिडायरेक्शनल एसोसिएशन को लागू करने के लिए, देखभाल की जानी चाहिए ताकि यूनिडायरेक्शनलिटी बनी रहे। विभिन्न बहुलता के लिए कार्यान्वयन निम्नानुसार हैं -
Optional Associations- यहां, भाग लेने वाली वस्तुओं के बीच एक लिंक मौजूद हो सकता है या नहीं। उदाहरण के लिए, नीचे दिए गए आंकड़े में ग्राहक और चालू खाते के बीच संबंध में, ग्राहक के पास चालू खाता हो सकता है या नहीं भी हो सकता है।
कार्यान्वयन के लिए, चालू खाता की एक वस्तु ग्राहक में एक विशेषता के रूप में शामिल की गई है जो NULL हो सकती है। C ++ का उपयोग करके कार्यान्वयन -
class Customer {
private:
// attributes
Current_Account c; //an object of Current_Account as attribute
public:
Customer() {
c = NULL;
} // assign c as NULL
Current_Account getCurrAc() {
return c;
}
void setCurrAc( Current_Account myacc) {
c = myacc;
}
void removeAcc() {
c = NULL;
}
};
One–to–one Associations- यहां, एक वर्ग का एक उदाहरण संबंधित वर्ग के ठीक एक उदाहरण से संबंधित है। उदाहरण के लिए, विभाग और प्रबंधक में एक-से-एक एसोसिएशन है जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
यह विभाग में शामिल करके कार्यान्वित किया जाता है, प्रबंधक की एक वस्तु जो NULL नहीं होनी चाहिए। C ++ का उपयोग करके कार्यान्वयन -
class Department {
private:
// attributes
Manager mgr; //an object of Manager as attribute
public:
Department (/*parameters*/, Manager m) { //m is not NULL
// assign parameters to variables
mgr = m;
}
Manager getMgr() {
return mgr;
}
};
One–to–many Associations- यहां, एक वर्ग का एक उदाहरण संबंधित वर्ग के एक से अधिक उदाहरणों से संबंधित है। उदाहरण के लिए, निम्नलिखित आकृति में कर्मचारी और आश्रित के बीच संबंध पर विचार करें।
इसे कर्मचारी वर्ग के आश्रितों की सूची में शामिल किया गया है। C ++ STL सूची कंटेनर का उपयोग करके कार्यान्वयन -
class Employee {
private:
char * deptName;
list <Dependent> dep; //a list of Dependents as attribute
public:
void addDependent ( Dependent d) {
dep.push_back(d);
} // adds an employee to the department
void removeDeoendent( Dependent d) {
int index = find ( d, dep );
// find() function returns the index of d in list dep
dep.erase(index);
}
};
द्वि-दिशात्मक संघ
द्वि-दिशात्मक एसोसिएशन को लागू करने के लिए, दोनों दिशाओं में लिंक बनाए रखने की आवश्यकता होती है।
Optional or one–to–one Associations - परियोजना और परियोजना प्रबंधक के बीच के संबंध में एक-से-एक द्विदिश संघ के संबंध में विचार करें जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
C ++ का उपयोग करके कार्यान्वयन -
Class Project {
private:
// attributes
Project_Manager pmgr;
public:
void setManager ( Project_Manager pm);
Project_Manager changeManager();
};
class Project_Manager {
private:
// attributes
Project pj;
public:
void setProject(Project p);
Project removeProject();
};
One–to–many Associations - डिपार्टमेंट और एम्प्लॉई के बीच एक-से-कई एसोसिएशन होने के संबंध पर विचार करें जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
C ++ STL सूची कंटेनर का उपयोग करके कार्यान्वयन
class Department {
private:
char * deptName;
list <Employee> emp; //a list of Employees as attribute
public:
void addEmployee ( Employee e) {
emp.push_back(e);
} // adds an employee to the department
void removeEmployee( Employee e) {
int index = find ( e, emp );
// find function returns the index of e in list emp
emp.erase(index);
}
};
class Employee {
private:
//attributes
Department d;
public:
void addDept();
void removeDept();
};
संघों को कक्षाओं के रूप में लागू करना
यदि किसी एसोसिएशन में कुछ विशेषताएं जुड़ी हुई हैं, तो इसे एक अलग वर्ग का उपयोग करके लागू किया जाना चाहिए। उदाहरण के लिए, कर्मचारी और परियोजना के बीच वन-टू-वन एसोसिएशन पर विचार करें जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
C ++ का उपयोग करके कार्यबल का कार्यान्वयन
class WorksOn {
private:
Employee e;
Project p;
Hours h;
char * date;
public:
// class methods
};
बाधाओं को लागू करना
कक्षाओं में अवरोधों की सीमा और प्रकारों को प्रतिबंधित किया जाता है जो कि विशेषताएँ ले सकते हैं। अवरोधों को लागू करने के लिए, एक मान्य डिफ़ॉल्ट मान को उस विशेषता को सौंपा जाता है जब किसी ऑब्जेक्ट को क्लास से तत्काल किया जाता है। जब भी मूल्य को रनटाइम में बदला जाता है, तो यह जांच लिया जाता है कि मूल्य मान्य है या नहीं। अमान्य मान को एक अपवाद हैंडलिंग दिनचर्या या अन्य विधियों द्वारा नियंत्रित किया जा सकता है।
Example
कर्मचारी वर्ग पर विचार करें जहां आयु एक विशेषता है जिसमें 18 से 60 की सीमा तक मान हो सकते हैं। निम्नलिखित C ++ कोड इसे शामिल करता है -
class Employee {
private: char * name;
int age;
// other attributes
public:
Employee() { // default constructor
strcpy(name, "");
age = 18; // default value
}
class AgeError {}; // Exception class
void changeAge( int a) { // method that changes age
if ( a < 18 || a > 60 ) // check for invalid condition
throw AgeError(); // throw exception
age = a;
}
};
राज्य चार्ट लागू करना
राज्य चार्ट आरेखों में राज्यों को लागू करने के लिए दो वैकल्पिक कार्यान्वयन रणनीतियों हैं।
कक्षा के भीतर गणना
इस दृष्टिकोण में, राज्यों को एक डेटा सदस्य (या डेटा सदस्यों के सेट) के विभिन्न मूल्यों द्वारा दर्शाया जाता है। मानों को स्पष्ट रूप से कक्षा के भीतर एक गणना द्वारा परिभाषित किया गया है। संक्रमणों का प्रतिनिधित्व सदस्य कार्यों द्वारा किया जाता है जो संबंधित डेटा सदस्य के मूल्य को बदलते हैं।
एक सामान्यीकरण पदानुक्रम में कक्षाओं की व्यवस्था
इस दृष्टिकोण में, राज्यों को एक सामान्यीकरण पदानुक्रम में इस तरह से व्यवस्थित किया जाता है कि उन्हें एक सामान्य सूचक चर द्वारा संदर्भित किया जा सकता है। निम्नलिखित आंकड़ा राज्य चार्ट आरेख से एक सामान्यीकरण पदानुक्रम में परिवर्तन दिखाता है।
डेटाबेस सिस्टम को ऑब्जेक्ट मैपिंग
वस्तुओं की दृढ़ता
ऑब्जेक्ट-ओरिएंटेड सिस्टम को विकसित करने का एक महत्वपूर्ण पहलू डेटा की दृढ़ता है। दृढ़ता के माध्यम से, वस्तुओं को उस प्रोग्राम की तुलना में लंबा जीवनकाल है जो इसे बनाया था। निरंतर डेटा को द्वितीयक संग्रहण माध्यम पर सहेजा जाता है, जहाँ से आवश्यकता पड़ने पर इसे पुनः लोड किया जा सकता है।
RDBMS का अवलोकन
एक डेटाबेस संबंधित डेटा का एक संग्रह है।
एक डेटाबेस प्रबंधन प्रणाली (DBMS) सॉफ्टवेयर का एक संग्रह है जो डेटाबेस में डेटा को परिभाषित करने, बनाने, संग्रहीत करने, हेरफेर करने, पुनर्प्राप्त करने, साझा करने और निकालने की प्रक्रियाओं को सुविधाजनक बनाता है।
रिलेशनल डेटाबेस मैनेजमेंट सिस्टम (आरडीबीएमएस) में, डेटा को संबंधों या तालिकाओं के रूप में संग्रहीत किया जाता है, जहां प्रत्येक स्तंभ या फ़ील्ड एक विशेषता का प्रतिनिधित्व करता है और प्रत्येक पंक्ति या ट्यूपल एक उदाहरण के रिकॉर्ड का प्रतिनिधित्व करता है।
प्रत्येक पंक्ति को विशिष्ट रूप से न्यूनतम विशेषताओं के चुने हुए सेट द्वारा विशिष्ट रूप से पहचाना जाता है primary key।
ए foreign key एक विशेषता है जो संबंधित तालिका की प्राथमिक कुंजी है।
RDBMS में टेबल्स के रूप में कक्षाओं का प्रतिनिधित्व करना
डेटाबेस तालिका में कक्षा को मैप करने के लिए, प्रत्येक विशेषता को तालिका में फ़ील्ड के रूप में दर्शाया जाता है। या तो एक मौजूदा विशेषता (एस) को एक प्राथमिक कुंजी के रूप में सौंपा गया है या एक अलग आईडी फ़ील्ड को प्राथमिक कुंजी के रूप में जोड़ा गया है। आवश्यकता के अनुसार वर्ग को क्षैतिज या लंबवत रूप से विभाजित किया जा सकता है।
उदाहरण के लिए, सर्कल क्लास को तालिका में परिवर्तित किया जा सकता है जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।
Schema for Circle Table: CIRCLE(CID, X_COORD, Y_COORD, RADIUS, COLOR)
Creating a Table Circle using SQL command:
CREATE TABLE CIRCLE (
CID VARCHAR2(4) PRIMARY KEY,
X_COORD INTEGER NOT NULL,
Y_COORD INTEGER NOT NULL,
Z_COORD INTEGER NOT NULL,
COLOR
);
डेटाबेस टेबल्स के लिए मानचित्रण संघ
एक-से-एक संघ
1: 1 संघों को लागू करने के लिए, किसी एक तालिका की प्राथमिक कुंजी को अन्य तालिका की विदेशी कुंजी के रूप में सौंपा गया है। उदाहरण के लिए, विभाग और प्रबंधक के बीच संबंध पर विचार करें -
SQL तालिका बनाने के लिए आदेश देता है
CREATE TABLE DEPARTMENT (
DEPT_ID INTEGER PRIMARY KEY,
DNAME VARCHAR2(30) NOT NULL,
LOCATION VARCHAR2(20),
EMPID INTEGER REFERENCES MANAGER
);
CREATE TABLE MANAGER (
EMPID INTEGER PRIMARY KEY,
ENAME VARCHAR2(50) NOT NULL,
ADDRESS VARCHAR2(70),
);
एक-से-कई संघ
1: एन एसोसिएशन को लागू करने के लिए, एसोसिएशन के 1-साइड में टेबल की प्राथमिक कुंजी को एसोसिएशन के एन-साइड में टेबल की विदेशी कुंजी के रूप में सौंपा गया है। उदाहरण के लिए, विभाग और कर्मचारी के बीच संबंध पर विचार करें -
SQL तालिका बनाने के लिए आदेश देता है
CREATE TABLE DEPARTMENT (
DEPT_ID INTEGER PRIMARY KEY,
DNAME VARCHAR2(30) NOT NULL,
LOCATION VARCHAR2(20),
);
CREATE TABLE EMPLOYEE (
EMPID INTEGER PRIMARY KEY,
ENAME VARCHAR2(50) NOT NULL,
ADDRESS VARCHAR2(70),
D_ID INTEGER REFERENCES DEPARTMENT
);
कई-से-कई संघ
एम: एन संघों को लागू करने के लिए, एक नया संबंध बनाया जाता है जो एसोसिएशन का प्रतिनिधित्व करता है। उदाहरण के लिए, कर्मचारी और परियोजना के बीच निम्नलिखित संघ पर विचार करें -
Schema for Works_On Table - WORKS_ON (EMPID, PID, HOURS, START_DATE)
SQL command to create Works_On association - बनाएँ कार्य कार्यों
(
EMPID INTEGER,
PID INTEGER,
HOURS INTEGER,
START_DATE DATE,
PRIMARY KEY (EMPID, PID),
FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
FOREIGN KEY (PID) REFERENCES PROJECT
);
टेबल्स के लिए मैपिंग इनहेरिटेंस
विरासत का नक्शा बनाने के लिए, बेस टेबल (एस) की प्राथमिक कुंजी को प्राथमिक कुंजी के साथ-साथ व्युत्पन्न तालिका (ओं) में विदेशी कुंजी के रूप में सौंपा गया है।
Example