I have a couple of specific questions regarding ER modelling.
To provide some specific context, this is for a university project and I seem to not be able to hunt down specific answers to these questions.
Background
ER Model
Questions
Partner and Personal Assistant are both subclass entities and per my diagram there is a mandatory 1..1 relationship. Is it "legal" to have a specific relationship between subclasses?
I have used an optional, or relationship for the subclasses of Staff, which I think is fine as a staff member cannot be any of the roles at the same time. The only omitted role as a subclass is that of "auditor". If I were to include this, would "optional, or" change to "mandatory, or", as all possible options are shown and the staff member must be one of those 4 roles?
Between Annual_audit and Staff I have a relationship entity (I could be calling this something wrong there). Is this the correct way to show the relationship? I tried using a ternary relationship as well, but ended up going backwards and forwards several times.
Any general feedback or pointing out of errors is most welcome
Many thanks for any help anyone is able to provide.
Partner and Personal Assistant are both subclass entities and per my diagram there is a mandatory 1..1 relationship. Is it "legal" to have a specific relationship between subclasses?
It's perfectly valid to have relationships between subtypes and/or supertypes.
I have used an optional, or relationship for the subclasses of Staff, which I think is fine as a staff member cannot be any of the roles at the same time. The only omitted role as a subclass is that of "auditor". If I were to include this, would "optional, or" change to "mandatory, or", as all possible options are shown and the staff member must be one of those 4 roles?
That sounds correct. I'd rather use the term "disjoint" than "or".
Between Annual_audit and Staff I have a relationship entity (I could be calling this something wrong there). Is this the correct way to show the relationship? I tried using a ternary relationship as well, but ended up going backwards and forwards several times.
There's no such thing as a "relationship entity" in the ER model. You may be thinking of associative entities which are used in the network data model to decompose many-to-many relationships. The ER model supports many-to-many relationships directly and don't need associative entities for this purpose, though they still have a place in subjecting relationships to other relationships.
Annual_audit
in your diagram is a weak entity relation. Staff
is a regular entity relation. Between them is Charges time
which is a many-to-many relationship relation. The notation is readable enough if you know the concepts. Chen's notation would represent the concepts more clearly though, while diagrams that look like table schemas work better for physical models.
One problem with your diagram is the arrow heads. They're inconsistent with the cardinality indicators. They cardinality indicators look correct, but the arrow heads mostly don't point in meaningful directions. I would remove them all except the one pointing from the subtypes to Staff
.
Finally, I suggest you don't mix OOP and data modeling concepts and terminology. Data modeling is for representing knowledge, OOP is for modeling systems. Use "subtyping" for subtypes/subsets of entity sets, "subclassing" for derived classes in a programming context.