A better way would be to separate the addresses and persons into different record sets. The first record set might look like this:
%rec: Person %type: Dob date %type: Abode rec Residence Name: Alfred Nebel Dob: 20 April 2010 Email: email@example.com Abode: 42AbbeterWay Name: Mandy Nebel Dob: 21 February 1972 Email: firstname.lastname@example.org Mobile: 0555 342123 Abode: 42AbbeterWay Name: Bertram Nebel Dob: 3 January 1966 Email: email@example.com Abode: 42AbbeterWay Name: Charles Spencer Dob: 4 July 1997 Email: firstname.lastname@example.org Abode: 2SerpeRise Name: Dirk Spencer Dob: 29 June 1945 Email: email@example.com Mobile: 0555 342123 Abode: 2SerpeRise Name: Ernest Wright Dob: 26 April 1978 Abode: ChezGrampa
and the second (which follows in the same file), like this:
%rec: Residence %key: Id Address: 42 Abbeter Way, Inprooving, WORCS Telephone: 01234 5676789 Id: 42AbbeterWay Address: 2 Serpe Rise, Little Worning, SURREY Telephone: 09876 5432109 Id: 2SerpeRise Address: 1 Wanter Rise, Greater Inncombe, BUCKS Id: ChezGrampa
Here you can see that there are two record sets viz:
There are six persons, but only three residences, because some residences
accommodate more than one person.
Note also that the
Residence descriptor has the entry
Person descriptor has
%type: Abode rec Residence.
This is because
Abode is the foreign key which identifies the residence
where a person lives.
We could have declared the
Id field as
%auto. This would have had
the advantage that we need not manually update it.
However, we decided that the
Abode field values in the
are better as alphanumeric fields, so that they can contain
human readable values. In this way, it is self-evident by reading a
record where that person lives.
Yet since the
Id field is declared using the
%key special field
name, you can be sure that you don't accidentally reuse an existent key.