REDEFINE command

From m204wiki
Jump to navigation Jump to search

Summary

Privileges
File manager
Function
Modifies the definition of a field in a Model 204 file

Syntax

REDEFINE [FIELD] {field-description [field-description]... | fieldname WITH attribute [attribute]...}

Where:

field-description takes the following form:

fieldname [(attribute [attribute]...)]

fieldname (1 to 255 characters) is the name of a field in the open Model 204 file.
attribute is one of those listed in the table below. All attributes are described in detail in the Model 204 File Manager's Guide.
Field description attributes

Field description attribute

Abbreviation

BINARY-LARGE-OBJECT

BLOB

CHARACTER-LARGE-OBJECT

CLOB

DEFERRABLE

DEF

NON-DEFERRABLE

NDEF

FEW-VALUED *

FV

MANY-VALUED *

MV

FRV (for-each-value)

-

NON-FRV

NFRV

KEY

-

NON-KEY

NKEY

LEVEL k

LVL k

[NUMERIC] RANGE

NR

NON-RANGE

NNR

ORDERED

-

NON-ORDERED

NORD

UNIQUE

UNIQ

NON-UNIQUE

NUNIQ

UPDATE IN PLACE

UP

UPDATE AT END

UE

* You can specify FEW-VALUED and MANY-VALUED only if a field is being redefined from NON-FRV NON-CODED to FRV NON-CODED.

Syntax notes

If FIELD is specified or the WITH form of the REDEFINE command is used, only one field can be redefined; otherwise, multiple fields can be redefined.

The attributes must be enclosed in parentheses unless WITH is specified.

Attributes must be separated by commas or by one or more blanks.

REDEFINE can be specified only in file context.

Example

REDEFINE SOC SEC (KEY,NR,LEVEL 0) REDEFINE AGE WITH KEY

Usage notes

The REDEFINE command allows the file manager to alter a field definition without having to reinitialize or reload the file in which the field is stored.

The file manager can specify as many attributes as are needed. OCCURS, LENGTH, and PAD (see DEFINE FIELD) cannot be included. For each attribute, only one of the alternatives shown above can be specified. For example, either KEY or NON-KEY can be specified, but not both.

If an attribute is specified in the DEFINE command, but not changed by the REDEFINE, that attribute remains in effect for the field.

A field can be REDEFINED with the UNIQUE attribute. However, if non-unique values are found during REDEFINE processing, the REDEFINE fails and the following error message is produced for each non-unique value:

*** M204.1701: NON-UNIQUE VALUE value FOUND FOR FIELD fieldname IN RECORD NUMBER n; CONFLICTS WITH RECORD NUMBER n

FIELD keyword

The keyword FIELD is required before field names that begin with the word FIELD, PRINTER, or DATASET. It is optional before other field names. If FIELD is specified, only one field can be redefined per command.

The following examples both redefine a field with the name POLICYHOLDER:

REDEFINE FIELD POLICYHOLDER (KEY) REDEFINE POLICYHOLDER (KEY)

The following example redefines a field with the name FIELD LOCATION. In this example the keyword FIELD must precede the name of the field name to avoid confusing Model 204:

REDEFINE FIELD FIELD LOCATION (ORD)

ORDERED fields

The NON-ORDERED and ORDERED attributes relate to the Ordered Index. The NON-ORDERED attribute can be used to eliminate the Ordered Index for a given field.

The ORDERED attribute followed by a new tree type can change the tree type of an ORDERED field. The tree type can be either CHARACTER or NUMERIC. Changing the tree type deletes the old tree type.

If a field already is defined as ORDERED, the REDEFINE command can change the related attributes by specifying the attribute and a new value. A change to the LRESERVE, NRESERVE, SPLITPCT, or IMMED attribute does not cause any change to the existing Ordered Index but modifies the effect of any updates.

Refer to the discussion of the "DEFINE FIELD: Field names and attributes" for more information on the Ordered Index field attributes.

The following example eliminates the Ordered Index for the TAX field:

REDEFINE TAX (NON-ORDERED)

The following example changes the tree type of the Ordered Index CHARGE field:

REDEFINE CHARGE (ORDERED CHAR)

The following example changes the related attributes of an Ordered Index field:

REDEFINE EXPENSE (IMMED 20)

Redefining CHUNK fields

Redefining OI chunk fields or OI chunk target fields is not allowed.

Redefining INVISIBLE fields

You cannot use the REDEFINE command to add a new index to a field with the INVISIBLE attribute that is in a file that has been used, so that MSTRADD is nonzero. For an invisible field the REDEFINE command cannot specify the KEY, ORD CHAR, and ORD NUM attribute nor the NUMERIC RANGE attribute, unless the field was originally defined with that attribute.

The behavior of the REDEFINE command changed in Version 5.1. Prior to Version 5.1, when you redefined an invisible field with options that added a new index, such as KEY, NUMERIC RANGE, or ORDERED, the redefinition for the field was accepted. However, the new index was not actually built (and could not be because the field was invisible). Now, if you redefine an invisible field with options that specify a new index for the field, the redefinition is rejected with the following message:

M204.0411: CONFLICTING ATTRIBUTES: INVISIBLE FIELD WITH NEW INDEX

Exception

The following exception applies: in the case where no records have ever been stored in the file, and that case only, redefining an invisible field can specify options that add a new index for the field.

The behavior of the REDEFINE command does not change when used with invisible fields and options that do not add a new index for the field.

Update units

When it processes REDEFINE, Model 204 ends any update unit in progress and begins a non-backoutable update unit.

Redefining Large Object fields

You can redefine a Large Object field, if the file is empty and you specify that the that the field is (BLOB NCLOB) or (CLOB NBLOB). For example, the following statement is unsuccessful:

REDEFINE FLD_LOB (BLOB) *** 2 M204.0411: CONFLICTING ATTRIBUTES: BLOB AND CLOB

However, the following statement is successful:

REDEFINE FLD_LOB (BLOB NCLOB)

Furthermore, you can redefine a field as a Large Object field, if no data has been entered in the field. For example, the following statements are unsuccessful:

REDEFINE FLD_LOB (BLOB NCLOB) *** 2 M204.0411: CONFLICTING ATTRIBUTES: FILE NOT EMPTY REDEFINE FLD_LOB (KEY NCLOB) *** 2 M204.0411: CONFLICTING ATTRIBUTES: FILE NOT EMPTY