OOAD - กลยุทธ์การดำเนินการ
การใช้การออกแบบเชิงวัตถุโดยทั่วไปเกี่ยวข้องกับการใช้ภาษาโปรแกรมเชิงวัตถุมาตรฐาน (OOPL) หรือการออกแบบวัตถุการแม็ปกับฐานข้อมูล ในกรณีส่วนใหญ่เกี่ยวข้องกับทั้งสองอย่าง
การใช้งานโดยใช้ภาษาโปรแกรม
โดยปกติงานในการเปลี่ยนการออกแบบวัตถุเป็นรหัสเป็นกระบวนการที่ตรงไปตรงมา ภาษาโปรแกรมเชิงวัตถุใด ๆ เช่น C ++, Java, Smalltalk, C # และ Python รวมถึงการจัดเตรียมสำหรับการแสดงคลาส ในบทนี้เรายกตัวอย่างแนวคิดโดยใช้ C ++
รูปต่อไปนี้แสดงการเป็นตัวแทนของคลาส Circle โดยใช้ C ++
การดำเนินการสมาคม
ภาษาโปรแกรมส่วนใหญ่ไม่ได้จัดเตรียมโครงสร้างเพื่อใช้การเชื่อมโยงโดยตรง ดังนั้นงานในการดำเนินการเชื่อมโยงจึงต้องใช้ความคิดอย่างรอบคอบ
การเชื่อมโยงอาจเป็นได้ทั้งแบบทิศทางเดียวหรือแบบสองทิศทาง นอกจากนี้การเชื่อมโยงแต่ละสมาคมอาจเป็นแบบหนึ่งต่อหนึ่งหนึ่งถึงหลายสมาคมหรือหลายต่อหลายคน
สมาคมทิศทางเดียว
สำหรับการดำเนินการเชื่อมโยงทิศทางเดียวควรใช้ความระมัดระวังเพื่อให้คงความเป็นทิศทางเดียว การใช้งานสำหรับหลายหลากที่แตกต่างกันมีดังนี้ -
Optional Associations- ที่นี่ลิงค์อาจมีหรือไม่มีระหว่างวัตถุที่เข้าร่วม ตัวอย่างเช่นในการเชื่อมโยงระหว่างลูกค้าและบัญชีปัจจุบันในรูปด้านล่างลูกค้าอาจมีหรือไม่มีบัญชีปัจจุบันก็ได้
สำหรับการนำไปใช้งานจะรวมออบเจ็กต์ของบัญชีปัจจุบันเป็นแอตทริบิวต์ในลูกค้าที่อาจเป็นโมฆะ การใช้งานโดยใช้ 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- ที่นี่อินสแตนซ์หนึ่งของคลาสที่เกี่ยวข้องกับอินสแตนซ์หนึ่งของคลาสที่เกี่ยวข้อง ตัวอย่างเช่นแผนกและผู้จัดการมีการเชื่อมโยงแบบหนึ่งต่อหนึ่งดังแสดงในรูปด้านล่าง
สิ่งนี้ถูกนำไปใช้โดยรวมไว้ในแผนกซึ่งเป็นวัตถุของผู้จัดการที่ไม่ควรเป็นโมฆะ การใช้งานโดยใช้ 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 - พิจารณาความสัมพันธ์ระหว่าง Project และ Project Manager ที่มีการเชื่อมโยงแบบสองทิศทางแบบหนึ่งต่อหนึ่งดังแสดงในรูปด้านล่าง
การใช้งานโดยใช้ 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();
};
การนำสมาคมมาใช้เป็นชั้นเรียน
หากการเชื่อมโยงมีแอตทริบิวต์บางอย่างที่เชื่อมโยงควรดำเนินการโดยใช้คลาสแยกกัน ตัวอย่างเช่นพิจารณาความสัมพันธ์แบบหนึ่งต่อหนึ่งระหว่างพนักงานและโครงการดังแสดงในรูปด้านล่าง
การใช้งาน WorksOn โดยใช้ 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;
}
};
การติดตั้ง State Charts
มีกลยุทธ์การใช้งานทางเลือกสองวิธีในการใช้สถานะในแผนภาพแผนภูมิของรัฐ
การแจงนับภายในคลาส
ในแนวทางนี้สถานะจะแสดงด้วยค่าต่างๆของสมาชิกข้อมูล (หรือชุดของสมาชิกข้อมูล) ค่าถูกกำหนดอย่างชัดเจนโดยการแจงนับภายในคลาส การเปลี่ยนจะแสดงโดยฟังก์ชันสมาชิกที่เปลี่ยนค่าของสมาชิกข้อมูลที่เกี่ยวข้อง
การจัดชั้นเรียนในลำดับชั้นทั่วไป
ในแนวทางนี้สถานะต่างๆจะถูกจัดเรียงตามลำดับชั้นทั่วไปในลักษณะที่สามารถอ้างถึงโดยตัวแปรพอยน์เตอร์ทั่วไป รูปต่อไปนี้แสดงการเปลี่ยนแปลงจากแผนภาพแผนภูมิสถานะเป็นลำดับชั้นทั่วไป
การแมปวัตถุกับระบบฐานข้อมูล
ความคงอยู่ของวัตถุ
สิ่งสำคัญของการพัฒนาระบบเชิงวัตถุคือความคงอยู่ของข้อมูล วัตถุมีอายุการใช้งานยาวนานกว่าโปรแกรมที่สร้างขึ้นด้วยความคงอยู่ ข้อมูลถาวรจะถูกบันทึกไว้ในสื่อบันทึกข้อมูลสำรองซึ่งสามารถโหลดซ้ำได้เมื่อจำเป็น
ภาพรวมของ RDBMS
ฐานข้อมูลคือชุดข้อมูลที่เกี่ยวข้องตามลำดับ
ระบบการจัดการฐานข้อมูล (DBMS) คือชุดซอฟต์แวร์ที่อำนวยความสะดวกในกระบวนการกำหนดสร้างจัดเก็บจัดการเรียกค้นแชร์และลบข้อมูลในฐานข้อมูล
ในระบบการจัดการฐานข้อมูลเชิงสัมพันธ์ (RDBMS) ข้อมูลจะถูกจัดเก็บเป็นความสัมพันธ์หรือตารางโดยแต่ละคอลัมน์หรือฟิลด์แสดงถึงแอตทริบิวต์และแต่ละแถวหรือทูเพิลแสดงถึงเรกคอร์ดของอินสแตนซ์
แต่ละแถวจะถูกระบุโดยไม่ซ้ำกันโดยชุดแอตทริบิวต์ขั้นต่ำที่เลือกซึ่งเรียกว่า primary key.
ก foreign key เป็นแอตทริบิวต์ที่เป็นคีย์หลักของตารางที่เกี่ยวข้อง
การแสดงคลาสเป็นตารางใน RDBMS
ในการแมปคลาสกับตารางฐานข้อมูลแต่ละแอ็ตทริบิวต์จะแสดงเป็นฟิลด์ในตาราง มีการกำหนดแอตทริบิวต์ที่มีอยู่เป็นคีย์หลักหรือเพิ่มฟิลด์ ID แยกเป็นคีย์หลัก ชั้นเรียนอาจแบ่งในแนวนอนหรือแนวตั้งตามความต้องการ
ตัวอย่างเช่นคลาส Circle สามารถแปลงเป็นตารางได้ดังแสดงในรูปด้านล่าง
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: N คีย์หลักของตารางในด้าน 1 ของการเชื่อมโยงจะถูกกำหนดให้เป็นคีย์ต่างประเทศของตารางที่ด้าน N ของการเชื่อมโยง ตัวอย่างเช่นพิจารณาความสัมพันธ์ระหว่างแผนกและพนักงาน -
คำสั่ง 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
);
หลายต่อหลายสมาคม
ในการใช้การเชื่อมโยง M: N ความสัมพันธ์ใหม่จะถูกสร้างขึ้นซึ่งแสดงถึงการเชื่อมโยง ตัวอย่างเช่นพิจารณาความสัมพันธ์ต่อไปนี้ระหว่างพนักงานและโครงการ -
Schema for Works_On Table - WORKS_ON (EMPID, PID, HOURS, START_DATE)
SQL command to create Works_On association - สร้างตาราง WORKS_ON
(
EMPID INTEGER,
PID INTEGER,
HOURS INTEGER,
START_DATE DATE,
PRIMARY KEY (EMPID, PID),
FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
FOREIGN KEY (PID) REFERENCES PROJECT
);
การแมปมรดกกับตาราง
ในการแมปการสืบทอดคีย์หลักของตารางฐานจะถูกกำหนดให้เป็นคีย์หลักเช่นเดียวกับคีย์นอกในตารางที่ได้รับ
Example