Authored by Mark Beauchamp, Murali Ravuri
Introduction
Access reference data that is used in the application at real time to eliminate the possibility of stale data. It is recommended to follow a declarative and non-procedural approach to access reference data in order to avoid duplicating similar routines at multiple places, and to promote a centralized data access mechanism.
Consider a simple use case where a Loan Application Case uses the Applicants information. You can retrieve the applicant’s information by using a unique identifier. You must design this retrieval of the applicant’s information so that the data loads at real time and on demand.
You can access the reference data by using the following features:
- Data pages
- Linked properties
Data page
Data pages provide greater flexibility to access reference data. You can also use data pages to access external data that is sourced from a non-Pega application. You can configure a page property to refer to a data page that sources the information. You can use this page property across the application without any procedural code to load the referenced information.
The following image shows the definition of a page property, ApplicantInfo, in a Loan Application case. This page property is configured to access the data by referring to a data page. The value of the parameter to the data page is held in another property, ApplicantID.
If ApplicantID is populated with a valid value, you can then use this page property on UI rules, such as sections, or processing rules, such as data transforms, to refer to the applicant’s information.
The following image shows a page property sourced from a data page that is referred from a data transform.
data:image/s3,"s3://crabby-images/a4b52/a4b52acbb134778326f4327621e9bcc735a1280c" alt="Access RefDataImage1"
data:image/s3,"s3://crabby-images/c21c6/c21c61bb7485c7b51f0d2a5f54c21b04b3f45a82" alt="AccessrefData2"
Linked property
A property that holds the value of a key to an external record in the system is called a linked property. This property is a single-value (scalar) property, but by configuring the Data access to automatically refer to a class instance, the property behaves like a page that holds the information of the target record.
The following image shows the definition of the linked property, Applicant, in a Loan Application case, where the property holds the primary key (PersonID) of the Data-Person class record. If the reference class has more than one key, the values for the other keys can be passed from other properties that hold the value.
data:image/s3,"s3://crabby-images/0ef9c/0ef9c66d0e09338246d48e595084978d175d6e9c" alt="AccessRefData3"
The linked property appears as a scalar property on the case clipboard, but you can view the corresponding page that it refers to under Linked Property Pages in the left pane of the clipboard viewer.
If the linked property is used as a single-value property (from rules such as sections or data transforms), then it renders the actual value held in the property. However, if it is used as a page (for example, .Applicant.Name, from rules such as sections or data transforms), then it holds the corresponding record and acts as a page. An example is show in the following image:
data:image/s3,"s3://crabby-images/a2e00/a2e004c1722c4f51b36e0d5000fa647ea9d7bc37" alt="AccessRefData4"
Recommendations and limitations
- Referencing data pages is the recommended approach to use instead of using linked properties.
- Linked properties provide an alternative to using lookup data pages or Obj-Open in activities.
- References to properties within linked property pages do not show anything unless the appropriate key value is set on the linked property.
- Linked property pages remain on the clipboard until the next commit operation is performed, which reduces the memory footprint. Use linked properties on an as-needed basis.
- Linked property pages are not automatically removed from the clipboard while the thread that initiated it is active. It is recommended to use them sparingly.
- Overusing linked properties can cause a large amount of data to load into the clipboard, for example, referring to a linked property from each item in a long UI list in which each row refers to a unique record. Exercise caution while designing such use cases.
- Linked properties do not support dynamic class referencing. The property must be customized in the implementation layer to specialize the class.
References
https://community.pega.com/sites/default/files/help_v73/zstandardrules/rule-obj-propertylinked.htm