Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

The schema is like below

{
   id
   name
   surname
   employees {
      id
      name
      surname
   }
}

I was wondering if its oop representation could be

class Person {
   id
   name
   surname
}

class Employee extends Person {}

class Supervisor extends Person {
   List<Employee> employees;
}

So two classes will be inherited from the same class but one of them uses the other one within it self.

If this is not a good idea, what would be a better way of constructing this schema.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
4.6k views
Welcome To Ask or Share your Answers For Others

1 Answer

There is no inherent issue, in a language or OO sense, with Employee and Supervisor having a common superclass, and one depending on the other as well.

There is, however, a possible issue with the suitability of that approach for modelling your particular problem domain. In common English, most "supervisors" also have their own supervisors, and all supervisors, even the topmost, are ordinarily considered "employees" as well. Additionally, it is unclear whether your Person class serves any useful purpose: if all supervisors are also employees, then does your model need to accommodate any Persons who are not employees? It's not clear that it even makes sense to use different classes to distinguish between employees who are supervisors and those who are not.

My first inclination would be to go much simpler:

class Employee {
    int id;
    String name;
    String surname;
    List<Employee> employees;
}

Employees who are not supervisors would just have an empty employees list. And before you ask, no, it is not a problem for Employee to contain a List<Employee>.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...