Programming Microsoft Dynamics NAV(Fifth Edition)
上QQ阅读APP看书,第一时间看更新

FieldClass - FlowField

FlowField must be dynamically calculated. FlowFields are virtual fields stored as metadata; they do not contain data in the conventional sense. A FlowField contains the definition of how to calculate (at runtime) the data that the field represents and a place to store the result of that calculation. Generally, the Editable property for a FlowField is set to No.

Depending on the CalcFormula method, this could be a value, a reference lookup, or a Boolean value. When the CalcFormula method is Sum, the FieldClass property connects a data field to a previously defined SumIndexField in the table defined in CalcFormula. FlowField processing speed will be significantly affected by the key configuration of the table being processed. While we must be careful not to define extra keys, having the right keys defined will have a major effect on system performance, and thus on user satisfaction.

A FlowField value is always 0, blank or false, unless it has been calculated. If a FlowField is displayed directly on a page, it is calculated automatically when the page is rendered. FlowFields are also automatically calculated when they are the subject of predefined filters as part of the properties of a data item in an object (this will be explained in more detail in the discussions in Chapter 5, Queries and Reports on Reports and Chapter 8, Advanced NAV Development Tools on XMLports). In all other cases, a FlowField must be forced to calculate using the C/AL RecordName.CALCFIELDS(FlowField1, [FlowField2],...) function or by use of the function SETAUTOCALCFIELDS. This is also true if the underlying data is changed after the initial display of a page (that is, the FlowField must be recalculated to take a data change into account).

Because a FlowField does not contain actual data, it cannot be used as a field in a key; in other words, we cannot include a FlowField as part of a key. Also, we cannot define a FlowField that is based on another FlowField except in special circumstances.

When a field has its FieldClass property set to FlowField, another directly associated property becomes available: CalcFormula (conversely, the AutoIncrement, and TestTableRelation properties disappear from view when FieldClass is set to FlowField). CalcFormula is the place where we can define the formula for calculating the FlowField. On the CalcFormula property line, there is an ellipsis button. Clicking on that button will bring up the following screen:

Click on the drop-down button to show the seven FlowField methods:

The seven FlowFields are described in the following table:

The Reverse Sign control allows us to change the displayed sign of the result for FlowField types Sum and Average only; the underlying data is not changed. If a Reverse Sign is used with the FlowField type Exist, it changes the effectpe function to does not Exist.

Table and Field allow us to define the Table and the Field within that table to which our Calculation Formula will apply. When we make the entries in our Calculation Formula screen, there is no validation checking by the compiler that we have chosen an eligible table with a field combination. That checking doesn't occur until runtime. Therefore, when we are creating a new FlowField, we should test it as soon as we have defined it.

The last, but by no means the least significant, component of the FlowField calculation formula is Table Filter. When we click on the ellipsis in the Table Filter field, the window shown in the following screenshot will appear:

When we click on the Field column, we will be invited to select a field from the table that was entered into the Table field earlier. The Type field choice will determine the type of filter. The Value field will have the filter rules define on this line, which must be consistent with the Type choices described in the following table: