I have 3 tables like this in MySQL 5:
| PERSON |
| id | fullName | isEmp | isParent |
| EMPLOYEE |
| personId | code |
| PARENT |
| personId | job |
in which, Employee.personId and Parent.personId are foreign keys pointing to Person.id. An employee can also be a parent and vice versa. So how can I config using Annotation of JPA 2.0/Hibernate 3? Thanks!
If a Person can be both, you can’t solve this through inheritance, because Java doesn’t allow multiple inheritance. So you’ll have to go with Aggregation, which is confusing on a semantic level, because it’s has-a-parent instead of is-a-parent. But I’m afraid it’s the way you’ll have to go:
(getters / setters etc. omitted)