Skip to content

IntegrityCheck

Jip Claassens edited this page Nov 24, 2023 · 9 revisions

In modelling, especially when complexity rises, errors are easily made.

The GeoDMS contains ways of assisting modeller's on tracking down and solving errors, think for instance on unit metric consistency.

Another useful feature is the configuration of integrity checks for data items.

An IntegrityCheck is used to check if an (intermediate) result meets certain requirements, for instance that all values need to be within a certain range or that no missing data may occur.

if an IntegrityCheck fails, the data of the resulting items can usually still be requested in a table view, in order to find out what is wrong. The data can not be exported.

If you write an expression in the IntegrityCheck, you can use 'this' to refer to itself. This is preferred.

container ReadOpbrengsten_perOP  := 
	for_each_neidv(OP/name
		, 'ReadOpbrengsten_perOP_UNCHECKED/'+OP/name
		, '(all(IsNull(this)))'
		, AdminDomain
		, EUR
	);

examples

No missing data

attribute<city> city_rel (neighborhood) := rlookup(city_code, regions/city/city_code)
, IntegrityCheck = "isDefined(city_rel)";

The attribute uses the rlookup function to find the relation to the regions/city domain unit.
The configured IntegrityCheck checks if for each neighborhood a city is found.

In such an IntegrityCheck it is allowed to refer to the item for which the IntegrityCheck is configured, the GeoDMS has a workaround to work with such self references.

Recent version

container root: IntegrityCheck = "GeoDmsVersion() >= 7.123"

This IntegrityCheck at the root container of the configuration checks if the configuration is opened in a GeoDMS version 7.123 or later.

see also

  • an integrity check can also be used in a for_each loop.
Clone this wiki locally