Sub Form Key Policy¶
If you have a survey with a key and a key policy of, for example, “merge”, then you may not always want sub forms or repeating groups to be treated the same way as the main form.
The Sub form key policy has no effect unless the Survey Keys policy is set to “merge” or “replace”.
Set as a parameter called “key_policy on a question of type “begin repeat”. This parameter can have one of 3 values
- replace. Each record in the sub-form is progressively merged with records previously recorded
- merge, Each record previously recorded is merged with the new records. Unlike “replace”, if the new record has an unanaswered question then the previous answer will be kept
- append. Records in the subform are appended to the existing sub-form records. This is the default
key_policy=merge key_policy=replace key_policy=append
Example 1 - Append sub form records¶
- You have a survey that is used to manage equipment.
- If a new photograph of that equipment is taken, (in the main form) then you want that to replace the existing photo.
- So a key of the equipment id is specified with a key policy of “merge”.
- However each time you use the survey you want to record a new meter reading and append it to all the other readings.
- In this case you can put the meter reading in a “begin repeat” group and and leave the sub form key policy unspecified (none) or set to “append” which will append new records.
Example 2 - Merge sub form records¶
This example is based on the medical clinics product
- A survey is used by a doctor to prescribed medication to a patient during a consultation. Each consultation is recorded in a sub form.
- A second survey then updates the data in the sub form to indicate which medications were dispensed
- Set the survey key of both surveys to the patient identifier. This is specified in the survey settings.
- Set the survey key policy on both surveys to merge.
- In the second dispensing survey, add the parameter “key_policy=merge” to the begin repeat that contains the results of the consultation.