Share via


FIELDERROR Function (Record)

Stops the execution of the code causing a run-time error, and creates an error message for a field.

Syntax

  
Record.FIELDERROR(Field, [Text])  

Parameters

Record
Type: Record

The record that contains the field.

Field
Type: Field

The field for which you want to create an error message.

Text
Type: Text or code

Use this optional parameter to include the text of the error message. If you do not use this parameter, then default text is used as shown in the following examples. You can use backslashes (\) to break lines.

Remarks

Like a run-time error, this function causes the system to automatically abort any transaction.

Programming Guidelines

We recommend the following guidelines for error messages:

  • Describe what is wrong and how to solve the problem.

  • Write a short descriptive message. Do not use more words than necessary.

  • Note that a period is automatically inserted at the end of a FIELDERROR.

  • Use a text constant for the Text parameter.

    For more information, see Progress Windows, MESSAGE, ERROR, and CONFIRM Functions.

Example 1

In the first example, there is no Text parameter and the field does not have a value. This example requires that you create a Record variable for the Customer table named CustomerRec.

CustomerRec."No." := '';  
CustomerRec.FIELDERROR("No.");  

The following message is displayed:

You must specify No. in Customer No.=''.

Example 2

In the next example, there is no Text parameter and the field has a value. This example requires that you create a Record variable for the Customer table named CustomerRec.

CustomerRec."No." := 'NEW 3500';  
CustomerRec.FIELDERROR("No.");  

The following message is displayed:

No. must not be NEW 3500 in Customer No.='NEW 3500'.

Example 3

The third example uses a non-empty string as the Text parameter. This example requires that you create the following variables and text constant in the C/AL Globals window.

Variable name DataType Subtype
CustomerRec Record Customer
Text constant name ConstValue
Text001 is not valid
CustomerRec."No." := 'NEW 3500';  
CustomerRec.FIELDERROR("No.", Text001);  

The following message is displayed:

No. is not valid in Customer No.='NEW 3500'.

See Also

Record Data Type