Object hierarchy
Most real-world applications represent data in a hierarchical or relational manner, with the data rationalized into discrete objects. There is often a central "root" object, which parents several other child objects, either as singular objects or as a collection. Each discrete object has its own set of data items that can be any number of types. The key principles we want to cover are as listed:
- A range of data types (string, integer, datetime) and an enumerated value
- Object hierarchy
- Multiple single child entities of the same type
- Collections of entities
Balancing these goals with simplicity, the data diagram we will work toward is as follows:

The purpose of each of these models is described in the following table:

Another perfectly valid approach would be to aggregate the addresses into a collection, much like we have done with our contacts, but I want to demonstrate using the same type of object (Address) in multiple properties.
With the high-level design in place, we are now in a position to write our classes. However, before we start on our data entities, let’s take a look at the data items.