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