OPNQRYF (Open Query File)

OPNQRYF Command syntax diagram

 

Purpose

The Open Query File (OPNQRYF) command opens a file that contains a set of database records that satisfies a database query request. Once opened, the file looks like a database file opened by using the Open Database File (OPNDBF) command, and the records in the file are accessed by high-level language programs that share the open data path (ODP). The path is closed, and all query resources are deallocated, by using the Close File (CLOF) command.

This command is used to do any combination of the following database functions:

More Command Functions: Following the parameter descriptions and the command examples in the Additional Considerations section. Included in it are subsections on:

 

Restrictions

  1. The user can use overrides to change the file, library, and member names specified on the FILE parameter. Overrides are ignored for the file and library specified on the FORMAT parameter, unless FORMAT(*FILE) is specified. Parameter values specified on an override command, other than TOFILE, MBR, LVLCHK, WAITRCD, SEQONLY, or INHWRT and SHARE, are ignored by the OPNQRYF command.
  2. The OPNQRYF command does not share an existing open data path (ODP) in the job or activation group. If an existing SHARE(*YES) ODP in the job or activation group has the same file, library, and member name as the open query file open data path (ODP), the query file does not open and an escape message is sent.
  3. Each subsequent shared open operation must use the same open options (such as SEQONLY) that are in effect when the OPNQRYF command is run.
  4. Some system functions (such as the Display Physical File Member (DSPPFM) and Copy File (CPYF) commands) do not share an existing open data path. The OPNQRYF command cannot be used with those functions.
  5. The file opened with the OPNQRYF command cannot be used in programs written in BASIC because BASIC does not share an existing open data path.
  6. In multithreaded jobs, this command is not threadsafe for distribute files and fails for distributed files that use relational databases of type *SNA. This command is also not threadsafe and fails for Distributed Data Management (DDM) files of type *SNA.
  7. Users of this command must have the following authorities:

    • Execute authority for any library that is needed to locate the files specified on the FILE and FORMAT parameters
    • Object operational authority and one or more of the following data authorities for any physical file or logical file specified on the FILE parameter:

      • Read authority if the file is opened for input (using option *INP)
      • Add authority if the file is opened for output (using option *OUT)
      • Update authority if the file is opened for updates (using option *UPD)
      • Delete authority if the file is opened for deletions (using option *DLT)
      • Read, add, update, and delete authority if the file is opened for all I/O operations (using option *ALL)

    • Object operational authority for any file specified on the FORMAT parameter
    • Use authority for any translate tables specified on the MAPFLD parameter (using option *USE)

 

Notes

  1. The Copy from Query File (CPYFRMQRYF) command can be used to copy data from a data path opened with the OPNQRYF command.
  2. More information about the OPNQRYF command is in the Database Programming topic in the Information Center.

 

Required Parameters

FILE
Specifies one or more files, members, and record formats that are processed by the open query file command. All files specified must be physical files, logical database files, or Distributed Data Management (DDM) files. If DDM files are used, all files they refer to must be on the same target system, and the target system must be an IBM iSeries 400 computer or IBM System/38.

The name of the file can be qualified by one of the following library values:

*LIBL: All libraries in the job's library list are searched until the first match is found.

*CURLIB: The current library for the job is searched. If no library is specified as the current library for the job, the QGPL library is used.

library-name: Specify the name of the library to be searched.

file-name: Specify the files, members, and record formats that are processed.

Element 1: Member Values

*FIRST: The oldest member created is used.

*LAST: The newest member created is used.

member: Specify the file member name.

Element 2: Record Format Values

*ONLY: Only the record format in the file is used. If no record format name is specified, *ONLY is the default. If the file has more than one record format, a record format name is specified.

record-format-name: Specify the name of the record format that is used. The record format must exist in the database file specified in the first part of the FILE parameter.

When more than one file, file member, and record format is specified, the query joins field values to create a single set of records. Any file specified in the list may be a physical, join logical, or SQL view. More information on SQL views is in the SQL Reference topic in the Information Center. The maximum number of physical file members that can be joined by a single query is 32. This limit includes the based-on physical file members for any join logical file member or SQL view member specified on the FILE parameter. The limit also includes each separate occurrence of the same physical file member when it is specified more than once in the list, either directly by name or by being referred to through a logical file member.

 

Optional Parameters

OPTION
Specifies the open option used for the query file. The options chosen on the first full open operation of a file are not changed on subsequent shared open operations. The user can specify either OPTION(*ALL) or up to four of the following values in any order:

*INP: Open the file for input. OPTION(*INP) is the only value allowed if join processing or group processing is requested, if UNIQUEKEY processing is specified, or if all the fields in the open query file record format (specified on the FORMAT parameter) are for input-only use.

*OUT: Open the file for output. In some high-level languages, output to certain files (such as files defined as 'direct access' in the high-level language program) is done by using a combination of input and updates. OPTION(*UPD) or OPTION(*ALL) is specified to use an open query file with such a program.

*UPD: Open the file for update operations. If an input operation comes before an update, *INP on the OPTION parameter must be specified when OPTION(*UPD) is specified.

*DLT: Open the file for delete operations. If each delete operation is preceded by an input operation, *INP on the OPTION parameter must be specified when OPTION(*DLT) is specified.

Other Single Values

*ALL: Opens the file for all operations (*INP, *OUT, *UPD, and *DLT).

FORMAT
Specifies the record format used for records made available by using the OPNQRYF command. The simple field names in the open query file record format must represent fields that are either defined on the MAPFLD parameter or are unique across all files, members, and record formats specified on the FILE parameter. The value for any field that has the same name as a field specified on the MAPFLD parameter is determined by the mapped-field definition on the MAPFLD parameter. The value for any field not defined on the MAPFLD parameter is determined by a mapping of the field with the same name in one of the based-on files, file members, and record formats specified on the FILE parameter. Only the name, type, length, decimal positions, keyboard shift, and usage attributes of each field specified in the record format that is identified on the FORMAT parameter are used for processing the OPNQRYF command. All other attributes are ignored. The attributes do not have to be the same. If they differ, the fields are mapped in a way similar to those described for the Change Variable (CHGVAR) command.

*FILE: The record format of the first or only entry on the FILE parameter is used. FORMAT(*FILE) is not allowed when more than one file, member, and record format are specified on the FILE parameter (therefore requiring a join query).

Element 1: File Name

The name of the file can be qualified by one of the following library values:

*LIBL: All libraries in the job's library list are searched until the first match is found.

*CURLIB: The current library for the job is searched. If no library is specified as the current library for the job, the QGPL library is used.

library-name: Specify the name of the library to be searched.

database-file-name: Specify the name of a physical or logical database file, or a Distributed Data Management (DDM) file that contains the record format that is used.

Element 2: Record Format Values

*ONLY: The only record format in the file is used. If no record format name is specified, *ONLY is the default. If the file has more than one record format, specification of a record format name is required.

record-format-name: Specify the name of the record format that is used. The record format must exist in the database file specified in the first part of the FORMAT parameter.

QRYSLT
Specifies the selection values used (before grouping) to determine which records are available by using the open query file.

*ALL: All records in the physical or logical files, members, and record formats specified on the FILE parameter (after join processing, if required) are selected.

'query-selection': Specify an expression of up to 5000 characters (enclosed in apostrophes) that describes the values used to determine which records are selected. Any logical expression formed from relations can be specified (such as *EQ and *NE) of field and constant values or functions of field and constant values. At least one field name is specified in each relation. However, a field cannot be specified that depends on an aggregate function either directly in its definition or indirectly by referring to a mapped field. Refer to the "Expressions" section of Additional Considerations for a complete list of the operators used for this parameter.

For example, to select all records for which the value of field CUSNBR is less than 7000 and the value of field BALDUE is greater than 90% of the value of field CRLIMIT, specify the following:

QRYSLT('CUSNBR<7000 *AND
BALDUE>CRLIMIT*0.9')

Each field name may be qualified with either a file name or number that indicates which element in the list of files, members, and record formats specified on the FILE parameter contains the field. The special value *MAPFLD may be used to qualify the field name if the field is defined on the MAPFLD parameter.

KEYFLD
Specifies the name of one or more key fields used to arrange the query records, or specifies that the access path sequence of the first or only file, file member, and record format specified on the FILE parameter is used to arrange the query records. If key field names are specified, the user must also indicate whether the part of the key associated with each key field is ascending or descending, and whether the records are arranged by the absolute value of a numeric key field. If the qualified key field specified is a double-byte character field, the data is arranged in a single-byte sequence.

All key fields for an open query file must appear in the query records processed through the file. The fields named in the record format identified on the FORMAT parameter must include all key fields for the open query file, even if KEYFLD(*FILE) is specified to use the existing access path of a keyed file.

*NONE: Key fields are not used to arrange the query records; therefore, any arrangement is acceptable. It is possible for the system to display query records in different arrangements if the same query is run twice, based on such factors as the current number of records in the file members being queried. KEYFLD(*NONE) allows the system more flexibility than other KEYFLD values to improve the performance record processing through the open query file.

*FILE: The query records have the same arrangement as the first file, file member, and record format specified on the FILE parameter. KEYFLD(*FILE) is specified even if the first file in the list has only an arrival sequence access path, in which case the query record arrangement matches the arrival sequence of the first file, file member, and record format specified on the FILE parameter.

When KEYFLD(*FILE) is specified and a sort sequence other than *HEX has been specified on the SRTSEQ parameter, you may receive your records in an order that does not reflect the true file order. If this is a key file, the query's sort sequence is applied to the key fields of the file and an informational message is sent. If the file has a sort sequence table or an alternative collating sequence table, it is ignored for the ordering. This allows users to indicate which fields to apply a sort sequence to without having to list all the field names. If a sort sequence is not specified for the query, the query is ordered as in releases previous to V2R3M0.

Element 1: Qualified Key Field Values

qualified-key-field-name: Specify one or more field names (up to 50 field names can be entered) used to define a keyed access path to arrange the query records. Each field name is qualified with either a file name or number that indicates which element in the list of files, members, and record formats specified on the FILE parameter contains the field. The special value *MAPFLD is also used to qualify the field name if the field is defined on the MAPFLD parameter.

Each field name on the KEYFLD parameter must be a field name that is defined in the query records specified on the FORMAT parameter. For example, if the value *MAPFLD is specified on the KEYFLD parameter, the name of the mapped field must be defined in the query records specified on the FORMAT parameter. The sum of the lengths of all key fields cannot be more than 10,000 bytes. In addition, if the sum of the lengths of the key fields is greater than 2000 bytes, *INP must be specified on the OPTION parameter.

Element 2: Key Field Order

*ASCEND: The part of the key defined by the specified key field is ordered by ascending key values.

*DESCEND: The part of the key defined by the specified key field is ordered by descending key values.

Element 3: Order by Absolute Value

*ABSVAL: The part of the key defined by the specified key field is arranged by the absolute value of the key field. *ABSVAL is specified together with either *ASCEND or *DESCEND, but it is ignored if the key field is not numeric. If *ABSVAL is not specified, the records are arranged by the signed value of a numeric key field.

UNIQUEKEY
Specifies whether the query is restricted to records with unique key values, and specifies how many of the key fields must be unique. If *ALL or number-of-key-fields is specified, null values are considered to be equal.

*NONE: None of the key fields specified on the KEYFLD parameter must be unique. All query records are available through the open query file, regardless of key value.

*ALL: All key fields specified on the KEYFLD parameter must be unique. If there are multiple query records with the same values for all of the key fields, only the first such record is available through the open query file.

number-of-key-fields: Specify the number of key fields that must be unique. This value must be no larger than the number of key fields determined by the KEYFLD parameter. If there are multiple query records with the same value for the specified number of consecutive key fields, only the first such record is available through the open query file.

JFLD
Specifies whether the query joins records from multiple file members, and specifies how to join field values from the files, members, and record formats specified on the FILE parameter in constructing the query records.

The first file, member, and record format specified on the FILE parameter is called the join primary, and all other elements specified on the FILE parameter are called join secondaries. The JFLD parameter specifies a list containing pairs of field names, where the first field in each pair provides a value that is used to select records in a join secondary that has the same value in the second field name of the pair.

The join from-field and to-field may be simple or mapped fields (specified on the MAPFLD parameter), but a field that depends on an aggregate function (either directly in its definition or indirectly by referring to a mapped field) cannot be used.

The join from-field and to-field are not required to have identical field attributes, but numeric fields cannot be mixed with character or double-byte character set (DBCS) fields, and character fields cannot be mixed with DBCS-only field types. If the fields do not have identical attributes, the system converts them to identical attributes for join processing. This change uses a packed decimal format if both fields are fixed-point numeric fields, or floating-point format if either field is of the floating-point type. The change for fixed-point numeric fields aligns the decimal points and pads with zeros. Numeric-type change truncates fractional digits if more than 31 total digits are required for fixed-point numbers, or drops some of the least significant digits if more than 15 total digits are required for floating-point numbers. Character and DBCS-open fields are changed by padding the shorter field with blanks. DBCS-either fields are padded with blanks if the field contains SBCS data or padded with double-byte blanks if the field contains DBCS data. DBCS-only fields are padded with double-byte blanks.

If more than one file is specified on the FILE parameter, and if the JDFTVAL(*NO) value and JORDER(*ANY) value are specified, the system takes information from the JFLD and QRYSLT parameters and derives the final join specifications. If a file is specified on the FILE parameter and the file is not referred to by the QRYSLT or JFLD parameters, all records for that file are logically joined to all other records created from the other files specified on the FILE parameter.

If either JDFTVAL(*YES), JDFTVAL(*ONLYDFT), or JORDER(*FILE) is specified, the join fields must be specified on the JFLD parameter.

*NONE: No join operation is specified. If more than one file is specified on the FILE parameter, and JDFTVAL(*NO) and JORDER(*ANY) is specified, the system automatically finds the join fields from the QRYSLT parameter.

Element 1: From-Field Name

qualified-from-field-name: Specify a field name to provide the value used to select records in a join secondary file, file member, and record format. The field name is qualified with either a file name or number that indicates which element in the list of files, file members, and record formats (specified on the FILE parameter) contains the field. The special value *MAPFLD can also be used to qualify the field name if the field is defined on the MAPFLD parameter.

A join from-field is either a simple field or a mapped field defined on the MAPFLD parameter. If JDFTVAL(*YES) or JDFTVAL(*ONLYDFT) is specified, it must depend only on fields contained in the join primary or in join secondaries specified on the FILE parameter ahead of the join secondary associated with the to-field of the pair.

Element 2: To-Field Name

qualified-to-field-name: Specify a field name used to select records from a join secondary file, file member, and record format in constructing the query records. The field name is qualified with either a file name or number that indicates which element in the list of files, file members, and record formats specified on the FILE parameter contains the field. The special value *MAPFLD is used to qualify the field name if the field is defined on the MAPFLD parameter.

A join to-field is either a simple field or a mapped field defined on the MAPFLD parameter. If JDFTVAL(*YES) or JDFTVAL(*ONLYDFT) is specified, it must depend only on fields contained in a single join secondary. If the join secondary is a join logical file, only fields contained in the primary physical file member for the join logical file are components of the join to-field. The sum of the lengths of all to-fields for each join secondary (after change, if the from-field and to-field attributes are not identical) cannot be more than 2000 bytes unless JDFTVAL(*NO) is specified. Up to 50 join field pairs are specified.

Element 3: Join Operators

join-operator: Specifies the type of join operation that is performed for the specified from-field and to-field. If JDFTVAL(*NO) and JORDER(*ANY) are specified, or if more than one join field pair is specified, a different join operator may be specified for each pair. If JDFTVAL(*YES), JDFTVAL(*ONLYDFT), or JORDER(*FILE) is specified, then only one join operator may be specified, regardless of the join pairs.

*EQ: An equal join operation is performed.

*GT: A greater than join operation is performed.

*LT: A less than join operation is performed.

*NE: A not equal join operation is performed.

*GE: A greater than or equal join operation is performed.

*LE: A less than or equal join operation is performed.

JDFTVAL
Specifies whether the query file includes join records that use default values for any of the fields. The default values are from a join secondary file that contains a record that does not match the corresponding record in the primary file. The matching attempted is the join criteria as specified on the JFLD parameter.

Join processing attempts to collect field values from the join primary and join secondaries. It does so by matching join from-field values to records in a join secondary that produce the appropriate values in the join to-field. If there are no records in a join secondary to produce the to-field values required for the pairs of join fields associated with the join secondary, this parameter specifies whether query records should be constructed by using default values for all fields obtained from the join secondary.

If the FILE parameter includes any join logical or SQL views, all join files must be compatible with the JDFTVAL value. If the data description specification (DDS) used to create a queried join logical file does not contain the JDFTVAL keyword, JDFTVAL(*NO) must be specified. If any join logical file specified on the FILE parameter has the JDFTVAL keyword, then all join logical files for this open query file must be created by using the JDFTVAL keyword, and JDFTVAL(*YES) must be used. If any files are SQL views, then JDFTVAL(*NO) is required.

If the JDFTVAL parameter is not compatible with the attributes of the join logical files or SQL views being processed, the join view files specified on the FILE parameter can be replaced with their based-on physical file members. The correct, additional from-field and to-field pairs can be provided on the JFLD parameter to join records from the physical file members in any way.

If more than one file is specified on the FILE parameter, and if either JDFTVAL(*YES) or JDFTVAL(*ONLYDFT) is specified, the system uses the join fields as specified on the JFLD parameter as the final join specifications.

*NO: Default values are not used to construct join query records.

*YES: Creates all records for the join operation, including those produced both with and without default values. If *YES is specified, no SQL views are allowed.

*ONLYDFT: Creates only the records produced by using default values in constructing the join operation. This option is used to include only exception records in the records available through the open query file. If *ONLYDFT is specified, no join logical files or SQL views can be specified on the FILE parameter.

JORDER
Specifies, for a join query, whether the join order must match the order specified on the FILE parameter. If the join order is varied, the query records are created in a different arrangement. If the value specified for the JDFTVAL parameter is *YES or *ONLYDFT, the JORDER parameter is ignored. The order specified on the FILE parameter is always preserved, because changing the join order can change which records are returned when JDFTVAL processing is required.

If more than one file is specified in the FILE parameter and JORDER(*FILE) is specified, the system uses the join fields as specified on the JFLD parameter as the final join specifications.

*ANY: Any join file order is allowed, and any such arrangement may be used by the system to create the result records. It is possible for a query to return result records in a different arrangement if the same query is run twice, consecutively (based on factors such as the current number of records in the files being queried). JORDER(*ANY) allows the system more flexibility to improve the performance of processing records through the open query file than any other JORDER parameter value.

*FILE: The order of the file, file member, and record format elements specified on the FILE parameter are preserved in the join operation.

GRPFLD
Specifies the field name or names used to group query results. One query record is created for each group of records (after join processing, if required) selected by the QRYSLT parameter. The group is defined by the collection of records that has the same set of values for the fields specified in the record format identified on the FORMAT parameter. If no field names are specified and group processing is required, the whole file is considered to be one group. Each query record that is created is either made available through the open query file or is discarded, depending on the selection values specified on the GRPSLT parameter. All null values within a grouping column are considered equal. To ensure an ascending sequence, the KEYFLD parameter must also be specified.

*NONE: Fields are not used to form groups. If the grouping function is required (because selection values are specified on the GRPSLT parameter, or an aggregate function is used by a field specified on the MAPFLD parameter), records selected by the values specified on the QRYSLT parameter are handled as a single group.

qualified-group-field: Specify one or more field names (up to 50) to group the query results. Each field name may be qualified with either a file name or number to indicate which element in the list of files, members, and record formats specified on the FILE parameter contains the field. The special value *MAPFLD may also be used to qualify the field name if the field is defined on the MAPFLD parameter.

A grouping field defined on the MAPFLD parameter cannot refer to an aggregate function in its definition (either directly, or indirectly through the use of another field specified on the MAPFLD parameter). The sum of the lengths of all grouping fields cannot exceed 2000 bytes.

GRPSLT
Specifies the selection values used after grouping to determine which records are available through the open query file.

*ALL: All records defined by the grouping function described in the GRPFLD parameter description are selected.

'group-selection': Specify an expression (up to 2000 characters enclosed in apostrophes) that describes the values used to determine which records are selected. Any logical expression formed from relations (such as *EQ and *NE) of field and constant values or functions of field and constant values are specified. Only grouping fields (specified on the GRPFLD parameter), constants, aggregate functions (such as %AVG and %STDDEV), and mapped fields (specified on the MAPFLD parameter) that are composed of grouping fields and aggregate functions can be referred to in any relation. At least one field must be specified in each relation. Refer to the "Expressions" section of Additional Considerations for a complete list of the operators used for this parameter.

For example, to select all records for which the value of grouping field OVRDUE is greater than or equal to 10, and the average value of field CREDIT in each group is less than 100, specify the following:

GRPSLT('OVRDUE>=10 *AND %AVG(CREDIT)<100')

Each field name may be qualified with either a file name or number that indicates which element in the list of files, file members, and record formats specified on the FILE parameter contains the field. The special value, *MAPFLD, may also be used to qualify the field name if the field is defined on the MAPFLD parameter.

MAPFLD
Specifies the definition of query fields that are either mapped to, or derived from, other fields. MAPFLD is generally not needed if the field names specified on other OPNQRYF command parameters are simple field names that exist in only one of the file, file member, and record format elements specified on the FILE parameter.

*NONE: Mapped fields are not needed. All field names specified on other parameters exist in some record format specified on the FILE parameter.

Element 1: Mapped Field

mapped-field-name: Specify the simple field name used on any other OPNQRYF command parameter that must refer to this mapped field. A qualified name is not allowed for the first part of the MAPFLD parameter list item. All specified mapped-field-name values must be unique. Refer to the "Expressions" section of Additional Considerations for a complete list of the operators used for this parameter.

Element 2: Field Definition Expression

'mapped-field-definition': Specify an expression (up to 256 characters enclosed in apostrophes) that defines the mapped field in terms of other fields that either exist in only one of the file, file member, and record format elements specified on the FILE parameter, or are defined by some other mapped field definition appearing earlier in the MAPFLD list. Either numeric operations or string operations are allowed, depending on the data type of the fields used in the definition. Refer to the "Expressions" section of Additional Considerations for a complete list of the operators used for this parameter.

For example, to define a mapped field named WHSPAR as the concatenation of the field WHRSE with the first 10 characters of field PART, specify the following:

MAPFLD((WHSPAR 'WHRSE *CAT %SST(PART 1 10)'))

Each field name is qualified with either a file name or a number that indicates which element in the list of files, file members, and record formats specified on the FILE parameter contains the field. The special value *MAPFLD is also used to qualify the field name if the field is defined in an earlier list item on the MAPFLD parameter.

Element 3: Mapped Field Type

field-type: Specify the field type for this mapped field, or specify *CALC to allow the system to calculate appropriate attributes (including field type) for the mapped field. *CALC is the default if no field type value is specified.

When *CALC is used, the field attributes are determined in one of two ways. The attributes either match the field definition in the record format identified on the FORMAT parameter, or (if the field is not in the record format on the FORMAT parameter) the attributes are calculated based on the expression specified in the mapped-field definition for this field. If the mapped field is used in the record format identified on the FORMAT parameter, either use *CALC or specify attributes (field type, field length, and field decimals) identical to those of the field in the record format specified on the FORMAT parameter.

The field type must be valid for the final result of the expression specified on the mapped-field definition. Character and numeric types are only mixed if the numeric type is in zoned decimal format and the field length and the length of the expression result are the same.

The following are the only DBCS mappings allowed on the MAPFLD parameter:

  • From character to DBCS-open type
  • From character to DBCS-either type
  • From character to DBCS-graphic type
  • From character to UCS2 graphic type
  • From HEX to DBCS-open type
  • From HEX to DBCS-either type
  • From HEX to DBCS-only type
  • From HEX to DBCS-graphic type
  • From HEX to UCS2-graphic type
  • From DBCS-either to DBCS-open type
  • From DBCS-either to HEX type
  • From DBCS-either to DBCS-graphic type
  • From DBCS-either to DBCS-either type
  • From DBCS-open to DBCS-open type
  • From DBCS-open to character type
  • From DBCS-open to DBCS-graphic type
  • From DBCS-open to HEX type
  • From DBCS-open to UCS2 graphic type
  • From DBCS-only to DBCS-only type
  • From DBCS-only to DBCS-open type
  • From DBCS-only to DBCS-either type
  • From DBCS-only to DBCS-graphic type
  • From DBCS-only to HEX type
  • From DBCS-graphic to DBCS-only type
  • From DBCS-graphic to DBCS-open type
  • From DBCS-graphic to DBCS-either type
  • From DBCS-graphic to DBCS-graphic type
  • From DBCS-graphic to UCS2-graphic type
  • From UCS2-graphic to HEX type
  • From UCS2-graphic to DBCS-open type
  • From UCS2-graphic to character type
  • From UCS2-graphic to DBCS-graphic type
  • From UCS2-graphic to UCS2-graphic type

The Query Field Structure table (see Table 1) shows the allowable field type and external field length values. It also shows the default field length and decimal positions and the internal field length (in bytes) for each type of field.

Element 4: Length

field-length: Specify the field length in number of digits for a numeric field, number of bytes for a character or DBCS field, or number of characters for a graphic field. A field length must be an even value for DBCS-only and DBCS-either field types. The range of valid lengths for each field type is shown in the Query Field Structure table. A field length value is specified if *CALC is used for the field type.

Element 5: Decimal Positions

field-decimals: Specify the number of decimal positions for a numeric field, expressed as a number of decimal digits, that is no larger than the total number of digits specified for the field length. If no value is given, the default value is assumed to be zero. A field decimal's value must not be specified for a binary or character field, or if *CALC is specified for the field type.

Element 6: CCSID Value

field-CCSID: Specify the CCSID (character code set identifier) being assigned to the mapped field being created. This parameter is valid only for fixed- or variable-length character, DBCS, or hexadecimal fields, or for *CALC fields that result in one of these types. If no value is specified, the CCSID is determined based on the CCSIDs of the fields and/or literal values specified on the MAPFLD definition.

Literal values in the MAPFLD definition are tagged with the job default CCSID. However, if the MAPFLD definition consists of only a literal value and the user specifies a field CCSID value, the literal will be tagged with that CCSID. This allows the user to tag a literal with a CCSID other than the job default CCSID.

Note: Normally, *HEX and *VHEX fields do not have an associated CCSID. Because of this, the data in the field is treated the same regardless of the default CCSID of the system that the data is being used on. However, if the user specifies a CCSID for a *HEX or *VHEX field, the CCSID overrides the hexadecimal attribute of the field (causing the field to be treated as *CHAR/*VCHAR), and the data in the field may be treated differently if it is moved to a system that has a different default CCSID.

For more information on CCSIDs, see the Globalization topic in the Information Center.

An example of the MAPFLD parameter, showing the use of field-type, field-length, field-decimals, and field-CCSID, is as follows:

MAPFLD((UNTPRICE 'TOTPRICE / UNTCOUNT' *DEC  7 2)
  (SHORTSTR '%SST(LONGSTR 1 5)' *CHAR 5 *N 930))
IGNDECERR
Specifies whether the system ignores decimal data errors during query file processing.

*NO: The system does not ignore decimal data errors.

*YES: The system ignores decimal data errors. When errors in decimal data are encountered, the invalid sign and/or digits are automatically changed to valid values.

OPNID
Specifies the identifier used to name the query file so it is referred to by the Close File (CLOF) command when it is closed or by the Position Database File (POSDBF) command when it is opened. The identifier must differ from the OPNID associated with any other file which was previously opened by using the OPNDBF command or OPNQRYF command, and which is not yet closed.

*FILE: The name of the first or only file specified on the FILE parameter is used for the open query file identifier.

open-identifier-name: Specify the name to associate with this open query file.

SEQONLY
Specifies whether sequential-only processing is used for the query file, and also specifies the number of records that can be processed as a group when read or write operations are performed on the open query file. The open query file open data path (ODP) uses a different SEQONLY value than the one specified on this parameter. It depends on other parameter values specified on the OPNQRYF command. A message is sent if the SEQONLY value is changed. More information about sequential-only processing is in the SEQONLY parameter description on the OVRDBF (Override Database File) command, and in the Database Programming topic in the Information Center.

Element 1: Sequential-Only Processing is Used

*YES: The open query file uses sequential-only processing. Number of records can be specified with this value.

Element 2: Number of Records That can be Processed

number-of-records: Specify the number of records that are processed as a group when read or write operations are performed with the open query file. If no number-of-records value is specified, the system calculates the number of records processed as a group.

Other Single Values

*NO: The file does not use sequential-only processing.

COMMIT
Specifies whether the SQL statements are run under commitment control.

Before a database file is opened under commitment control, the user must ensure that all files in the commitment transaction are journaled. If only the after images are being journaled, the system implicitly begins journaling both the before and the after images for the duration of the changes being made to files opened under this commitment definition.

*NO: The open query file is not placed under commitment control.

*YES: The open query file is placed under commitment control.

OPNSCOPE
Specifies the extent of influence (scope) of the open operation.

*ACTGRPDFN: The scope of the open operation is determined by the activation group of the program that called the OPNQRYF command processing program. If the activation group is the default activation group, the scope is the call level of the system program performing the open operation. If the activation group is a non-default activation group, the scope is that activation group. In a multi-threaded job, only those opens within the same thread and within the same activation group can share this ODP.

*ACTGRP: The scope of the open data path (ODP) is the activation group. Only those shared opens from the same activation group can share this ODP. In a multi-threaded job only those shared opens from the same activation group within the same thread can share this ODP. This ODP is not reclaimed until the activation group is deactivated, or until the Close File (CLOF) command closes the file.

*JOB: The scope of the open data path (ODP) is the job in which the open operation occurs. If the job is multi-threaded, only those opens from the same thread can share this ODP.

DUPKEYCHK
Specifies whether duplicate key feedback is returned on input/output (I/O) operations. Duplicate key feedback should be requested only for files that are processed by COBOL programs since this is the only high-level language (HLL) that utilizes the feedback. Duplicate key feedback should only be requested when it is used by the COBOL application since providing it can cause a performance degradation. More information on duplicate key feedback is in the Database Programming topic in the Information Center.

*NO: Duplicate key feedback is not returned on I/O operations.

*YES: Duplicate key feedback is returned on I/O operations.

ALWCPYDTA
Specifies whether the system is allowed to copy data from the files, file members, and record formats specified on the FILE parameter. If so, the system is allowed to open the query file to the copy. The system tries to avoid using a copy of the data because a copy does not reflect changes made to the database after the information is copied. However, certain requests (such as when key fields contained in multiple based-on files for a join are specified) require that the data be copied before the specified query functions are performed.

*YES: The system may use a copy of data from the files, file members, and record formats specified on the FILE parameter. A copy of the data is used only when it is needed to perform the requested query functions.

*NO: The system does not use a copy of data from the files, file members, and record formats specified on the FILE parameter. If it is necessary to use a copy of the data to perform the requested query functions, the query file is not opened and an error message is sent.

*OPTIMIZE: The system uses a sort routine to order the output from the files, file members, and record formats specified on the FILE parameter. A sort routine is used only if the KEYFLD parameter is specified, and if using a sort routine would improve query performance without conflicting with other OPNQRYF options.

A sort will improve the performance of a query that returns most or all of the records in the file or files specified on the FILE parameter.

Use a sort can increase the time required for the OPNQRYF command to process. This occurs because the sort is performed and all records to be returned through the query are processed while the OPNQRYF command is active. However, because the records are already processed, the reading of the records (by using either a program or the CPYFRMQRYF command) is very fast. Therefore, the overall time to process the query is reduced.

Specifying the KEYFLD parameter for the OPNQRYF command does not ensure that the query will use an index if ALWCPYDTA(*OPTIMIZE) is specified. If a sort routine is used, the file is not opened with indexed access. If the program reading the records from the OPNQRYF command requires indexed access (random processing rather than sequential processing), ALWCPYDTA(*YES) or ALWCPYDTA(*NO) should be specified.

When a sort is used, the query file's position is not changed when a ROLLBACK command is issued. Therefore, when a query is opened that has parameters, ROLLBACK commands that follow do not reset the queried file's position to where it was at the start of the unit of recovery.

Note: Do not specify ALWCPYDTA(*OPTIMIZE) if you require that a ROLLBACK command reposition the query file, or if you require that the queried file be opened with indexed access.

The following items are required before a sort is valid for the OPNQRYF command:

  • ALWCPYDTA(*OPTIMIZE) must be specified.
  • The OPTION parameter, if specified, must be *INP.
  • A value other than *FILE or *NONE must be specified on the KEYFLD parameter.
  • The UNIQUEKEY parameter must not be specified, or must specify *NONE.
  • The SEQONLY parameter, if specified, must be *YES.
  • If COMMIT(*YES) is specified, the level of record locking (LCKLVL parameter on the STRCMTCTL command) must not be *ALL.
  • The DUPKEYCHK parameter must not be specified, or must specify *NO.
  • The total buffer length of all fields in the file specified on the FORMAT parameter (or FILE parameter, if the FORMAT parameter is not specified) must not exceed 32700 bytes.

The query optimizer determines whether a sort is used. This decision is based on the number of records expected from the query and the options specified on the OPNQRYF statement. The following items influence the optimizer's choice of a sort:

  • The OPTIMIZE parameter should specify *ALLIO or *MINWAIT. If *FIRSTIO is specified, the number of records specified should be close to or equal to the number of result records expected from the query.
  • The number of records in a file specified on the FILE parameter should contain a minimum of 200 records.
  • The query result should contain a minimum of 200 records.

OPTIMIZE
Specifies the most efficient way the system can perform the selection and join processing necessary to satisfy the other parameter specifications on the OPNQRYF command.

If the KEYFLD or GRPFLD parameters require that an access path be built (when no existing access path is shared), the access path is built completely, regardless of the OPTIMIZE entry. Optimization primarily affects system operation when selection processing is performed.

*ALLIO: The system attempts to reduce the total input/output time required to process the whole query, assuming that all query records are read from the file.

Element 1: Time Reduction Options

*FIRSTIO: The system attempts to reduce the input/output time required to open the query file and to retrieve the first buffer of records from the file.

*MINWAIT: The system attempts to reduce the time required to open the query file by minimizing delays when records are read from the file.

Element 2: Number of Records to Retrieve

number-of-records: Specify the number of query records to use in the optimize operation. This value is ignored when the value *MINWAIT is specified.

OPTALLAP
Specifies whether the query optimizer should consider all the access paths that exist over the files being queried when determining how to implement the query.

*NO: Allow the query optimizer to operate normally. When determining how to implement a query, the optimizer considers access paths until an internal timeout value has been exceeded. If there are a large number of access paths over the files being queried, the optimizer may time out before it has considered all the available access paths.

*YES: Force the query optimizer to ignore the internal timeout value and consider all the available access paths over all the files in the query.

Note: If there are a large number of access paths over the files it may take a long time to optimize the query.

SRTSEQ
Specifies the sort sequence to be used for sorting and grouping selections specified on the QRYSLT or GRPSLT parameters, joins specified on the JFLD parameter, ordering specified on the KEYFLD parameter, grouping specified on the GRPFLD parameter, %MIN or %MAX built in functions, or unique key values specified on the UNIQUEKEY parameter.

*JOB: The SRTSEQ value for the job is retrieved for the job.

*HEX: A sort sequence table is not used. The hexadecimal values of the characters are used to determine the sort sequence.

*LANGIDUNQ: A unique-weight sort table is used.

*LANGIDSHR: A shared-weight sort table is used.

The name of the sort sequence table can be qualified by one of the following library values:

*LIBL: All libraries in the job's library list are searched until the first match is found.

*CURLIB: The current library for the job is searched. If no library is specified as the current library for the job, the QGPL library is used.

library-name: Specify the name of the library to be searched.

table-name: Specify the name of the sort sequence table to be used with this query.

LANGID
Specifies the language identifier to be used when SRTSEQ(*LANGIDUNQ) or SRTSEQ(*LANGIDSHR) is specified.

*JOB: The LANGID value for the job is retrieved for the job.

language-ID: Specify the language identifier to be used by the job.

TYPE
Specifies the recursion level at which the Reclaim Resources (RCLRSC) command closes the file.

Note: This parameter is ignored unless the default value is specified on the OPNSCOPE parameter and the request is from the default activation group.

*NORMAL: The RCLRSC command closes the file if the program call that ran the OPNQRYF command is ended without closing the file.

*PERM: The file remains open until the Close File (CLOF) command closes it, or until the routing step or default activation group ends. The query file remains open even if the RCLRSC command is run.

Table 1. Query Field Structure

Type Field Type External
Field Length
Default Length
and Decimals
Internal Field
Length in Bytes
Binary
Binary
Floating-point
Floating-point
Packed decimal
Zoned decimal
Character
Variable length character
Hex
Variable length hex
DBCS-only
DBCS-either
DBCS-open
DBCS-graphic
Variable length DBCS-only
Variable length DBCS-either
Variable length DBCS-open
Variable length DBCS-graphic
Date
Time
Timestamp
*BIN2
*BIN4
*FLT4
*FLT8
*DEC
*ZONED
*CHAR
*VCHAR
*HEX
*VHEX
*ONLY
*EITHER
*OPEN
*GRAPHIC
*VONLY
*VEITHER
*VOPEN
*VGRAPHIC
*DATE
*TIME
*TIMESTP
1-5
1-10
1-9
1-17
1-31
1-31
1-32766
0-32740
1-32766
0-32740
4-327663
4-327663
4-32766
1-163835
0-32740
0-32740
0-32740
0-163705
5-104
4-84
14; 16-264
 5   02
10   02
 7   61
15  141
15   51
15   51
32
32
32
32
32
32
32
32
32
32
32
32
8
7
26
2
4
4
8
1-16
1-31
1-32766
0-32740
1-32766
0-32740
4-32766
4-32766
4-32766
2-32766
0-32740
0-32740
0-32740
0-32740
4
3
10
1
If the number of decimal digits is specified, but the decimal precision value is omitted for an *FLT4, *FLT8, *DEC, or *ZONED field, the precision defaults to zero decimal digits.
2
A nonzero value is not allowed for the decimal precision of a binary number.
3
The field length must be an even-numbered value.
4
These fields can be longer if they are padded on the right with blanks.
5
These field lengths are in a number of graphic characters.

Examples for OPNQRYF

Example 1: Selecting Specific Records

Note: Additional examples of selecting records using the OPNQRYF command can be found in the Database Programming topic in the Information Center.

OPNQRYF   FILE(ordfile)  OPTION(*all)
  QRYSLT('orddate=%range("840101" "841231")
  & ordamt>100')
  KEYFLD((ordamt *descend))

This command uses the QRYSLT parameter to select only records in the first member of file ORDFILE that have an order date in 1984 and an order amount greater than 100. Because the FORMAT parameter is omitted, the open query file has the same record format as file ORDFILE. The open query file allows all file operations (input, output, update, and delete). The KEYFLD specification is used to force the records to be arranged by descending value of order amount.

Example 2: Using the %XLATE Built-In Function

OPNQRYF   FILE(telefile)
  QRYSLT('%xlate(usrname qsystrntbl) *ct "GEORGE"')

This command uses the %XLATE built-in function to translate the field USRNAME to uppercase, and to instruct the *CT operator to select only records that contain the value GEORGE in the field USRNAME. QSYSTRNTBL is an IBM-supplied system translation table that converts lowercase alphabetics (a through z) to uppercase (A through Z). The translation is done to ensure that the search value is recognized even if its characters appear in mixed case. The records available through the open query file have the same record format as those in file TELEFILE.

Example 3: Using the %XLATE Built-In Function

OPNQRYF   FILE(telefile)
  QRYSLT('usrname *ct ''GEORGE''')
  MAPFLD((usrname
  '%xlate(telefile/usrname qsystrntbl)'))

In the previous example, the value of field USRNAME, which is returned to the high-level language (HLL) program that reads records from the open query file, is not translated to uppercase.

This example shows a way to make the uppercase version of field USRNAME available to the HLL program. This is done by defining a mapped field (MAPFLD parameter) for the translated value of field USRNAME. The field has the same field name as the field name in the open query file record format being used. The translated version of the field is used for selection (QRYSLT parameter) and is used in the open query file record format.

Example 4: Using the %SST Built-In Function

OPNQRYF   FILE((histlib/ordfile hist1))
  OPTION(*inp *upd *dlt)
  FORMAT(ordinfo orddtls)
  QRYSLT('month=7')
  MAPFLD((year '%sst(orddate 1 2)' *zoned 2)
  (month '%sst(orddate 3 2)' *zoned 2)
  (day '%sst(orddate 5 2)' *zoned 2))

This command uses the %SST built-in function to create a substring of the year, month, and day parts of character field ORDDATE in file ORDFILE. The command also maps a character string to a zoned field, which is valid as long as the zoned field has the same length as the character string. If the file ORDINFO has a record format, ORDDTLS, containing at least the field's YEAR, MONTH, and DAY records, these fields have input-only usage in the open query file record format because they are defined by using a built-in function (%SST) and are mappings that mix character and numeric (zoned decimal format) types. The file is opened for input, update, and delete operations, but none of the field's YEAR, MONTH, and DAY records are updated using the open query file open data path (ODP). The open query file uses only records in the HIST1 member of file ORDFILE in library HISTLIB, and the records retrieved through the file have the same format as record format ORDDTLS in file ORDINFO. Only records pertaining to the month of July are processed through the open query file (QRYSLT parameter).

Example 5: Returning the First Record of Each Set

OPNQRYF   FILE((routelf *first locusr))
  QRYSLT('%sst(toloc 1 4) *eq "ROCH"')
  KEYFLD(fromusr fromloc tousr toloc)
  UNIQUEKEY(*all)

This command uses the KEYFLD and UNIQUEKEY parameters to return only the first record of each set of records in record format LOCUSR in the first member of file ROUTELF that have the same values for the fields FROMUSR, FROMLOC, TOUSR, and TOLOC. The query result is further restricted by selecting only records that have the value ROCH in the first four characters of field TOLOC. The records available through the open query file contain all of the fields in record format LOCUSR of file ROUTELF. If the file ROUTELF contains information about messages routed by an application, this example identifies all unique sender and receiver pairs in which the receiving location name begins with ROCH.

Example 6: Joining a File to Itself

OPNQRYF   FILE(partpf partpf)
  FORMAT(partjoin)
  JFLD((1/pnbr 2/pnbr *GE))
  MAPFLD((pnm1 '1/pname') (pnm2 '2/pname')
  (pnbr '1/pnbr'))

This example illustrates how a file is joined to itself, as well as how to use the MAPFLD parameter to rename fields in the based-on files. A greater than or join is performed using field PNBR as both the join from-field and the join to-field.

The format of file PARTJOIN is assumed to contain fields named PNBR, PNM1, and PNM2. The field name PNBR is valid in the query output record format because that field is defined on the MAPFLD parameter. If the record format in file PARTJOIN contains a field named PNAME, an error occurs because the field exists in both files specified on the FILE parameter, and is not the name of a field defined on the MAPFLD parameter. The mapped field definitions are field names, so the attributes of fields PNM1 and PNM2 match the attributes of field PNAME, and the attributes of field PNBR in the open query file records match field PNBR in file PARTPF. Further, when a file is joined to itself, it is always necessary to specify a file number name for any field that is defined in the based-on file.

Example 7: Renaming Fields in Based-On Files

The same query can also be specified as follows:

OPNQRYF   FILE(partpf partpf)
  FORMAT(partjoin)
  QRYSLT('1/pnbr *GE 2/pnbr')
  MAPFLD((pnm1 '1/pname') (pnm2 '2/pname')
  (pnbr '1/pnbr'))

Because more than one file is specified on the FILE parameter, and the default value is specified for the JDFTVAL and JORDER parameters, the system takes the join specifications from the values specified on the QRYSLT parameter.

Example 8: Selecting Master Records With No Detail Records

OPNQRYF   FILE(cusmas ordfil)
  FORMAT(cusmas)
  JFLD((cusnbr ordfil/cusnbr))
  JDFTVAL(*onlydft)
  MAPFLD((cusnbr 'cusmas/cusnbr'))

This command uses a join query to select only master records that have no associated detail records. The master file (CUSMAS) is joined (equal join) to the detail file (ORDFIL) by the customer number field that appears in both record formats. The customer number field name is the same in both record formats (CUSNBR). Because CUSNBR is the name of a field defined on the MAPFLD parameter, everywhere the simple field name CUSNBR is used, the mapped field version of the CUSNBR field in file CUSMAS is used (including the open query file record format, which matches the customer master file record format). The JDFTVAL parameter indicates that only records that are produced by using default values are available through the open query file. Every master record that has associated detail records (with the same value of the customer number field) is excluded, and every master record that has no associated detail records creates a result record.

Example 9: Identifying Detail Records With No Associated Master Record

OPNQRYF   FILE(ordfil cusmas)
  FORMAT(ordfil)
  JFLD((cusnbr cusmas/cusnbr))
  JDFTVAL(*onlydft)
  MAPFLD((cusnbr 'ordfil/cusnbr'))

This change of the previous example (using the same files) shows how to identify all detail records with no associated master record (in this case, all orders with an unregistered customer number):

Example 10: Calculating Basic Statistics

OPNQRYF   FILE(scores)
  FORMAT(clsstats)
  GRPFLD(clsid)
  GRPSLT('clsavg<70 & clsmax-clsmin>30')
  MAPFLD((clscnt '%count')
         (clsavg '%avg(usrscore)')
         (clsmin '%min(usrscore)')
         (clsmax '%max(usrscore)'))

This command uses the grouping function to calculate basic statistics for each group of records in file SCORES that have the same value in the field CLSID. Assuming file CLSSTATS has a record format containing field CLSID and all fields specified on the MAPFLD parameter, each record available through the open query file contains the value of the grouping field (CLSID) as well as the number of records included in the group and the average, minimum, and maximum values of field USRSCORE in the group. Selection occurs after grouping, so that records are created for groups only when the average value of USRSCORE in the group is less than 70 and the difference between the maximum and minimum scores in the group is greater than 30.

Example 11: Selecting Records With a Specific Value

OPNQRYF   FILE(itmmast)
  QRYSLT('itmcode=%range(32 50) & itmtype="P"')
  ALWCPYDTA(*no)
  OPTIMIZE(*firstio)
  SEQONLY(*yes 10)
  TYPE(*perm)

This command selects from the first member of file ITMMAST only the records that have a value of field ITMCODE in the range from 32 through 50 and also have a value of field ITMTYPE equal to the letter P. The ALWCPYDTA parameter specifies that the open query file must never use a copy of the records in file ITMMAST. The OPTIMIZE and SEQONLY parameter values cause the system to attempt to improve processing for the open query file to minimize the time needed to retrieve the first buffer of ten records. This combination of parameter values is a good choice if the file is used with a high-level language interactive inquiry program that shares the open query file open data path (ODP) and shows ten records on each display screen. The open data path (ODP) for the open query file is 'permanent' (TYPE parameter), which means that it remains open either until the file is closed by using the Close File (CLOF) command or until the routing step ends.

Example 12: Tagging a Literal with a Specific CCSID

OPNQRYF   FILE(itmmast)
  QRYSLT('itmtype=pfield')
  MAPFLD((pfield 'P' *CHAR 1 *N 930))

This command selects from the first member of file ITMMAST only the records that have a value of field ITMTYPE equal to the letter 'P' in character set 930. The mapped field is created so that the literal 'P' can be tagged with a specific CCSID.

If a literal is not tagged with a specific CCSID, it is assigned the CCSID of the job running the query. Because of this, if an OPNQRYF statement is part of a CL program that is shared among systems with differing CCSIDs (in different countries, perhaps), a query that uses a literal in the selection specifications may not return the same results on all systems, even though the data in the files is the same. This happens because the internal representation of the literal may be different when the CL program is run in a job with a different CCSID. This representation then may not match the same records in the file. Note that the internal representation of the data in the file does not change based on the CCSID of the current job.

Tagging the literal with a specific CCSID avoids this problem. A literal tagged with a specific CCSID keeps the same internal representation on all systems. The CCSID that is used to tag the literal should be the same as the CCSID assigned to the field against which the literal is being compared.

Example 13: Using a Nonjoin Query

OPNQRYF   FILE((EMPLOYEE))  KEYFLD((NAME))
  ALWCPYDTA(*OPTIMIZE)

This command returns all of the records in the EMPLOYEE file.

Example 14: Using a Join Query

OPNQRYF   FILE((EMPLOYEE) (MANAGEMENT))
  FORMAT(EMPLOYEE)  KEYFLD((NAME))
  JFLD((1/EMPID 2/MEMPID))  ALWCPYDTA(*OPTIMIZE)

This command returns all of the records required by the join criteria.

Additional Considerations

The file, library, and file member names used by the open data path (ODP) are the same as the first file and file member names specified on the FILE parameter, unless an override forces the use of a different file or file member name. The record format name of the open query file is the same as that specified on the FORMAT parameter.

The OPNQRYF command always opens a file with an open data path (ODP) that is shared, as if SHARE(*YES) is specified for the file. If the file, library, or file member name specified in the HLL program differs from the name of the open query file, an override command must be used to specify the correct file, library, and member names to allow the high-level language program to share the open query file ODP. If the first, or the only, member queried has an attribute of SHARE(*NO), SHARE(*YES) must be specified in an override to enable an HLL program to share the query file ODP.

If the OPNQRYF is scoped to the job, any subsequent open, other than a query open, of the same file can share the ODP whether scoped to an activation group or the job. If the OPNQRYF is scoped to an activation group, any subsequent open, other than a query open, of the same file can share the ODP if it is also scoped to the same activation group.

The open query file ODP also has a LVLCHK attribute that matches the first, or only, member used for the query. Shared opens of an open query file are level checked unless the first queried member has an attribute of LVLCHK(*NO) or LVLCHK(*NO) is specified either in the program that opens the file or in an override which occurs before the shared open. The level number for the open query file record format is the same as the record format identified on the FORMAT parameter.

An expanded discussion of field names, expressions, and built-in functions, and restricted built-in functions used with parameters on the OPNQRYF command follows:

Field Names

The field name used as the first part of an element in the list specified on the MAPFLD parameter must be a simple name, and the field names in the record format identified on the FORMAT parameter are always treated as simple names. Any other field name specified on an OPNQRYF command parameter (QRYSLT, KEYFLD, JFLD, GRPFLD, GRPSLT, or the field-definition expression part of the MAPFLD parameter) is a qualified field name, specified as follows:

field-name
Specify a simple field name that identifies a field that is defined on the MAPFLD parameter, or with a field name that is unique among all field names from all record formats included in the list specified on the FILE parameter. This form is not allowed if there is no MAPFLD parameter definition for the specified field name and the FILE parameter includes more than one record format that contains a field with the specified name, even if the same file and record format is specified more than once in the list on the FILE parameter.

For example, AMOUNT is valid if the field named AMOUNT is defined on the MAPFLD parameter. It is also valid if AMOUNT is not defined on the MAPFLD parameter, as long as there is only one field named AMOUNT in any record format specified on the FILE parameter.

file-name/field-name
Specify a field name that is qualified with the simple name of the file specified on the FILE parameter whose record format contains the field, but only if the simple file name is unique among all file names specified on the FILE parameter. This form is not allowed if the same simple file name is specified more than once in the list specified for the FILE parameter, even if different library, member, or record format names are used.

For example, WHS01/PARTNBR is valid if there is a field named PARTNBR in the record format for file WHS01, and file name WHS01 is only specified once on the FILE parameter.

file-nbr/field-name
Specify a simple field name that is qualified with the number of the element in the FILE parameter list for the record format that contains the field. The file-nbr qualifier must be specified without leading zeros. This form is only required if the same simple file name is specified more than once in the list specified on the FILE parameter.

For example, 2/BALDUE is valid if the second file record format in the list specified on the FILE parameter contains a field named BALDUE.

*MAPFLD/field-name
Specify a simple field name that is qualified with the special value *MAPFLD if the field is defined on the MAPFLD parameter. When the field is defined, this form has the same meaning as specifying the simple field name with no qualifier. If the field is not defined on the MAPFLD parameter, *MAPFLD cannot be specified.

For example, *MAPFLD/AVGBAL is valid if the AVGBAL field is specified as the first part of one of the mapped field list elements specified on the MAPFLD parameter.

Expressions

Expressions specified on the QRYSLT, GRPSLT, and MAPFLD parameters are similar to expressions specified on other CL command parameters. Logical, relational, numeric, and string operations are performed by using combinations of field values and constants. Symbolic and named operators are supported, as well as many built-in functions, and parentheses are used to control the order of evaluation.

There are also differences in the expressions specified on OPNQRYF parameters and on other CL command parameters. The following list summarizes the ways that expressions on the QRYSLT, GRPSLT, and MAPFLD parameters differ from normal CL expressions:

The following table shows the priority of all operators that are used for expressions on the QRYSLT, GRPSLT, or MAPFLD parameters. Only operators listed for priorities 1 through 5, excluding the *NOT and not symbol operators, are allowed in an expression specified on the MAPFLD parameter:

Priority Operators
1 +, - (when used for signed numeric values), *NOT, not symbol
2 **
3 *, / ,// (a / must have a space before the / and/or after the /)
4 +, - (when used between two operands)
5 *CAT, v symbolv symbol
6 *GT, *LT, *EQ, *GE, *LE, *NE, *NG, *NL, *CT, >, <, =, >=, <=, not symbol=, not symbol>,

not symbol<

7 *AND, &
8 *OR, *XOR, v symbol, &&

Except for operators not symbol and *NOT, the operators for priorities 1 through 4 are numeric operators, which require numeric operands. The operators for priority 5 are string operators, which require operands to be either character or DBCS strings. Priority 6 operators are called relational operators, which require at least one operand that is a field name or a numeric or string expression (not a constant). The operators for priorities 7 and 8, plus the not symbol and *NOT operators (priority 1), are logical operators. The operands in a logical expression are relations (constructed by using a relational operator with appropriate operands) and other logical expressions.

The operands in a string expression, including string operands for a built-in function, are a combination of character fields and DBCS fields and constants. If both operands of such an expression are DBCS-only fields or constants, the final result from evaluation of the expression is a DBCS-only field value. If the operands are a combination of DBCS or character fields or constants, the result is a DBCS-open field value. When DBCS fields are concatenated, the extraneous shift-in and shift-out characters between the fields are removed.

The result produced by a + or - sign prefixed operator has the same attributes as the operand, unless the operand of a - sign prefixed operator is a *BIN2, in which case the result is a *BIN4. The result of an ** operator (exponentiation) is a double-precision floating-point number (*FLT8). For other numeric operators that require two operands, if either operand is a floating-point number, the result is a double-precision floating point number (*FLT8). If both operands are fixed-point numbers, the system uses the information in the following table to determine the number of total and fractional digits required to produce a packed decimal (*DEC) result. If both operands are zero-precision binary fields and/or integer constants, the result is a *BIN4, unless the operator is a "/". In that case, the result is the same as for a fixed-point result. If the total number of digits required exceeds 31, the number of fraction digits is reduced enough to enable calculation of the result with a total of 31 digits. If some fraction digits are dropped and the attributes of the end result of the computation (the attributes specified on the MAPFLD parameter for the field) require greater precision than that of the intermediate result, a warning message is sent to indicate that some precision was lost in evaluating the expression.

Operation Result
(Total Digits)
Result
(Fractional
Digits)
+ MAX(d1-f1,d2-f2)+MAX(f1,f2)+1 MAX(f1,f2)
- MAX(d1-f1,d2-f2)+MAX(f1,f2)+1 MAX(f1,f2)
* d1+d2 f1+f2
/ 31 31-(d1-f1+f2)
// MIN(d1-f1,d2-f2)+MAX(f1,f2) MAX(f1,f2)
Legend:
d1
Total digits in operand 1
f1
Fractional digits in operand 1
d2
Total digits in operand 2
f2
Fractional digits in operand 2

When a numeric or string expression is specified on the MAPFLD parameter, the attributes of the final result are used in one of two ways. They are either used directly for the field value (if field-type *CALC is specified and the field is not contained in the prototype record format identified on the FORMAT parameter), or the final result is changed to match the attributes specified on the MAPFLD parameter or contained in the field definition in the record format identified by the FORMAT parameter.

Both operands of a relational operator can be constants. The fields, constants, or expressions specified as operands on the left and right side of a relational operator must be of the same type, either numeric or string. Any combination of character and DBCS field operands are allowed except that a character field cannot be related to a DBCS-only field.

There are two types of DBCS constants: DBCS-only and DBCS-open. A DBCS-only constant has only DBCS data between its apostrophes. This data must be enclosed in SO/SI characters. A DBCS-open constant has a mixture of DBCS and alphameric data. An SO character (HEX 0E) indicates the start of a group of DBCS characters and an SI character (HEX 0F) follows the last double-byte character of the group.

If a numeric or string expression appears as a complex selection operand on the QRYSLT or GRPSLT parameters, attributes of the final result of the expression used for the selection operand are changed to match the other relational operand.

It is not necessary for operands of a relational operator to have identical attributes, but numeric operands cannot be mixed with character operands. If the operands do not have identical attributes, the system changes them to identical attributes (except for the *CT operator, where the character string operands may be of different lengths), before performing the operation. This change uses packed decimal format if both operands are fixed-point numeric operands, or floating-point format if either operand is a floating-point number. The changes for fixed-point numeric operands align their decimal points and pad them with zeros. Numeric type changes may truncate fractional digits if more than 31 total digits are required for fixed-point numbers, or may drop some of the least significant digits if more than 15 total digits are required for floating-point numbers. Character operands are changed by padding the shorter operand with blanks.

The *CT operator performs a scan of the character field or string expression (except for expressions made up of a single character string literal) that must be specified as the left side of the relation, in order to determine if it contains the character string, field, or expression value specified as the right side of the relation. The second operand (the search value) must be no longer than the first operand (the base string).

If the string is found, the relation is satisfied and the result is a logical value of 'true'; otherwise, the result is a logical 'false' value. The following example illustrates this process:

Field BASEFLD contains the value 'THIS IS A TEST'.

Field TESTFLD contains the value 'TE'.

Expression Result
'BASEFLD *CT ''IS A''' True
'BASEFLD *CT TESTFLD' True
'BASEFLD *CT ''X''' False
'BASEFLD *CT TESTFLD v symbolv symbol ''Z''' False
'BASEFLD v symbolv symbol ''ABC'' *CT ''TAB''' True

Built-in Functions

The built-in functions listed below are supported for the expression used to define a derived field on the MAPFLD parameter or a complex selection operand specified on the QRYSLT or GRPSLT parameters.

A numeric argument is a numeric field, a numeric constant or a numeric expression. A string argument is a character field, a character string literal, or a string expression. Unless otherwise noted, all built-in functions allow expressions, including other built-in functions, to be used as arguments.

For a field that appears in the record format identified by the FORMAT parameter, and that is also defined by an expression on the MAPFLD parameter, the expression result is calculated by using the attributes described below. Then the resultant value is mapped to match the attributes of the field.

%ABSVAL (numeric-argument)
%ABSVAL accepts a numeric argument and returns the absolute value of the argument. The returned value has the same attributes as the argument, unless the argument is a *BIN2, in which case the returned value is a *BIN4.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a packed decimal number (*DEC) with 8 digits and 0 precision (date duration), 6 digits and 0 precision (time duration), or 20 digits and 6 precision (timestamp duration).

%ACOS (numeric-argument)
%ACOS accepts a numeric argument and returns the arc cosine of the argument, in radians. %ACOS and %COS are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%AND (string-argument ...)
%AND accepts two or more character or hexadecimal string arguments and returns a string that is the bit-wise 'AND' (logical and) of the arguments. This function takes the first argument string, ANDs it with the next string, and continues to AND each successive argument with the previous result. If an argument is encountered that is shorter than the previous result, it is padded on the right with blanks. The returned value is a string of type *HEX with the same length as the longest argument. If any of the arguments are variable-length, the maximum length is used as the length of the argument.

%ANTILOG (numeric-argument)
%ANTILOG accepts a numeric argument and returns the antilogarithm (base 10) of the argument. %ANTILOG and %LOG are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%ASIN (numeric-argument)
%ASIN accepts a numeric argument and returns the arc sine of the argument, in radians. %ASIN and %SIN are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%ATAN (numeric-argument)
%ATAN accepts a numeric argument and returns the arc tangent of the argument, in radians. %ATAN and %TAN are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%ATANH (numeric-argument)
%ATANH accepts a numeric argument and returns the hyperbolic arc tangent of the argument, in radians. %ATANH and %TANH are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%AVG (numeric-argument)
%AVG accepts a numeric argument and returns the average value of its argument for the group of records defined on the GRPFLD parameter. The argument must be a field name or an expression (not a literal).

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. If no records are selected, the result is the null value. Otherwise,

  • If the argument is fixed-point, the result is a packed decimal number (*DEC) with 31 total digits and the same number of integer digits as the argument.
  • If the argument is floating-point, the result is a double-precision floating-point number (*FLT8).
  • If the argument is date duration, time duration, or timestamp duration, the returned value is a packed decimal number (*DEC) with 31 digits and 0 precision (date duration), 31 digits and 0 precision (time duration), or 31 digits and 6 precision (timestamp duration).

%AVG is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

%CHAR (date/time-argument date/time-format)
%CHAR accepts a date/time argument and date/time format and returns the character representation of the argument using the specified format. The date/time argument can be a date, time, or timestamp field. The returned value is of type *CHAR and is tagged with the CCSID of the current job.

The date/time format is optional. If specified, it must be one of the following:

EUR
European format
ISO
International Standards Organization format
JIS
Japanese Industrial Standard format
USA
United States format

If the format is not specified, the job default format is used.

Example:
  OPNQRYF
     FILE(library/file)
     GRPFLD(charfld)
     GRPSLT('charfld = %CHAR(timefld "USA")')
%COS (numeric-argument)
%COS accepts a numeric argument and returns the cosine of the argument. The argument must be specified in radians. %COS and %ACOS are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%COSH (numeric-argument)
%COSH accepts a numeric argument and returns the hyperbolic cosine of the argument. The argument must be specified in radians.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%COT (numeric-argument)
%COT accepts a numeric argument and returns the cotangent of the argument. The argument must be specified in radians.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%COUNT
%COUNT does not support any arguments. It returns the count of the number of records contained in the group of records defined on the GRPFLD parameter. The returned value is a 4-byte binary number (*BIN4) with 10 total decimal digits and no fraction digits. %COUNT is an aggregate function that applies only to a query that uses the grouping function.

%CURDATE
%CURDATE does not support any arguments. It obtains the current date based on a reading of the time-of-day clock. The returned value is of type *DATE. The format and separator are derived from the job attributes.

%CURSERVER
%CURSERVER does not support any arguments. If only non-distributed files are specified then it obtains the current server name (or RDB name) of the local system. If distributed files are specified then it obtains the current server name (or RDB name) of the COORDINATOR node. The returned value is of type variable-length character (*VCHAR) with a maximum length of 18.

%CURTIME
%CURTIME does not support any arguments. It obtains the current time based on a reading of the time-of-day clock. The returned value is of type *TIME. The format and separator are derived from the job attributes.

%CURTIMESTP
%CURTIMESTP does not support any arguments. It obtains the current timestamp based on a reading of the time-of-day clock. The returned value is of type *TIMESTP. The format and separator will be derived from the job attributes.

%CURTIMEZONE
%CURTIMEZONE does not support any arguments. It obtains the current time zone. The returned value is a packed decimal number (*DEC) with 6 digits and 0 precision.

%DATE (date/time-argument)
%DATE accepts a date/time argument and returns a date. The date/time argument can be a date or timestamp field, a character or hexadecimal field containing the external form of a date, a date literal, or a numeric field or literal value in the range 1 - 3,652,059. The returned value is of type *DATE.
Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT(('%DATE(tstampfld) =         "1989-10-23"'))
%DAY (date/time-argument)
%DAY accepts a date/time argument and returns the day part of the value. The date/time argument can be a date or timestamp field, a date duration or timestamp duration (field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 8 digits and 0 precision for date duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 8 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

%DAYS (date/time-argument)
%DAYS accepts a date/time argument and returns an integer representation of the date. The date/time argument can be a date or timestamp field, a character or hexadecimal field containing the external form of a date, or a date literal. The returned value is of type *BIN4.

%DIGITS (numeric-argument)
%DIGITS accepts a numeric argument and returns a character representation of its numeric value, not including the sign or a decimal point. The result is tagged with the CCSID of the current job. For example, %DIGITS (-1.5) returns the character string 15. The numeric argument must not be a floating point number.

%DURDAY (integer-argument)
%DURDAY accepts an integer argument and returns a labeled duration of days. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition of the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a date or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURHOUR (integer-argument)
%DURHOUR accepts an integer argument and returns a labeled duration of hours. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a time or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURMICSEC (integer-argument)
%DURMICSEC accepts an integer argument and returns a labeled duration of microseconds. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURMINUTE (integer-argument)
%DURMINUTE accepts an integer argument and returns a labeled duration of minutes. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a time or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURMONTH (integer-argument)
%DURMONTH accepts an integer argument and returns a labeled duration of months. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a date or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURSEC (integer-argument)
%DURSEC accepts an integer argument and returns a labeled duration of seconds. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a time or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

%DURYEAR (integer-argument)
%DURYEAR accepts an integer argument and returns a labeled duration of years. The integer argument for this function can be a numeric expression, a field, or a literal.

This built-in function is allowed to stand by itself in the mapped-field-definition value on the MAPFLD parameter, and is allowed as part of an arithmetic (addition or subtraction) expression with a date or timestamp field on the QRYSLT, GRPSLT, or MAPFLD parameters.

Example:
 OPNQRYF
   FILE((library/file))
   QRYSLT('startfld > %CURDATE + oneyear *AND
           endfld   < %CURDATE + %DURYEAR(2)')
   MAPFLD((oneyear '%DURYEAR(1)'))
%EXP (numeric-argument)
%EXP accepts a numeric argument and returns a value that is the base of the natural logarithm (e) raised to a power specified by the argument. %EXP and %LN are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types may be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%HASH (expression-argument)
%HASH accepts a valid expression and returns a 4-byte binary number (*BIN4) with 10 total decimal digits and no fraction digits. The returned value will be the partition number of the record selected.

A valid expression cannot include aggregate functions such as %COUNT, %AVG, %MIN, %MAX, %SUM, and %STDDEV as operands to %HASH.

Use the %HASH function to determine what the partitions would be if the partitioning key was composed of EMPNO and LASTNAME. The following example returns the partition number for every row in EMPLOYEE.

Example:
  OPNQRYF
     FILE((CORPDATA/EMPLOYEE))
     FORMAT(FNAME)
     MAPFLD((HASH '%HASH((1/EMPNO) (1/LN))'))
%HEX (hexadecimal-argument)
%HEX accepts an argument and returns the hexadecimal equivalent of the argument's value. The hexadecimal argument can be of any type. The returned value is of type *CHAR, and is tagged with the CCSID of the current job.

%HOUR (date/time-argument)
%HOUR accepts a date/time argument and returns the hour part of the value. The date/time argument can be a time or timestamp field, a time duration or timestamp duration (either field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 6 digits and 0 precision for time duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 6 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT(('%HOUR(timefld2) = 12'))
%LEN (length-argument)
%LEN accepts one argument and returns the number of bytes used to represent the value unless the value is a graphic field type. If the value is a graphic field type, the number of graphic characters is returned. The length argument can be of any type. The returned value is of type *BIN4.
Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('%LEN(varlenfld) <= 30')
Argument Type         Result Length in Bytes
--------------------  ----------------------
Character             1-32766
Hex                   1-32766
DBCS-only             4-32766
DBCS-either           4-32766
DBCS-open             4-32766
DBCS-graphic          1-16383
Variable Character    0-32740
Variable Hex          0-32740
Variable DBCS-only    0-32740
Variable DBCS-either  0-32740
Variable DBCS-open    0-32740
Variable DBCS-graphic 0-16370
Date                  4
Time                  3
Timestamp             10
Binary *BIN4          2
Binary *BIN8          4
Floating point *FLT4  4
Floating point *FLT8  8
Packed decimal (p,s)  INTEGER(p/2)+1, (1-16)
Zoned decimal  (p,s)  p (1-31)
--------------------------------------------
p=precision, s=scale

String notes:

The %LEN function returns the length of the value as it is stored in the data space.

  • For fixed-length fields, the length is always the same as the declared size of the field, not the length of the actual data in the field.
  • For variable-length fields, the length is the length of the actual data in the field, including trailing blanks.

For example, assume FIXED10 is a *CHAR(10) field, and VAR10 is a *VCHAR(10) field. The following example shows results of the %LEN function:

%LEN Statement  Field Data    Result
--------------  ------------  ------
%LEN(fixed10)   '1234567890'  10
%LEN(fixed10)   '12345'       10
%LEN(var10)     '1234567890'  10
%LEN(var10)     '12345'        5
%LEN(var10)     '12345  '      7
%LEN(var10)     ''             0

%LN (numeric-argument)
%LN accepts a numeric argument and returns the natural logarithm of the argument. %LN and %EXP are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types may be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%LOG (numeric-argument)
%LOG accepts a numeric argument and returns the common logarithm (base 10) of the argument. %LOG and %ANTILOG are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types may be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%MAX (numeric-or-string-or-date/time-argument ...)
%MAX accepts one or more character-string, DBCS-string, numeric, or date/time arguments, and returns the largest value from the list. Date/time arguments are arguments of type *DATE, *TIME, or *TIMESTP, or arguments that are date, time, or timestamp durations. String arguments must be no longer than 256 bytes.

If only one argument is specified, this function returns the maximum value of its argument for the group of records defined on the GRPFLD parameter, and the returned value has the same attributes as the argument. If no records are selected, the result is the null value. If the single argument is a date duration, time duration, or timestamp duration, then the returned value is a packed decimal number (*DEC) with 8 digits and 0 precision (date duration), 6 digits and 0 precision (time duration), or 20 digits and 6 precision (timestamp duration). When a single argument is used, it must be a field name or an expression (not a literal). %MAX with only one argument is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

If multiple arguments are specified, %MAX returns the maximum value of all the arguments. All arguments must be either character-string, DBCS-string, numeric, or date/time values. This function calculates the maximum value of the first two arguments, and then continues to determine the maximum value of the previous result and the next successive argument. The final result is determined according to the following value conversion rules.

If an argument has different attributes than the previous result, the two values are converted to identical attributes and the operation continues. This conversion uses packed decimal if both values are fixed-point numeric values, or floating-point if either value is floating-point. The conversion for fixed-point numeric values aligns the decimal points and pads the values with zeros. Numeric type changes may truncate fractional digits if more than 31 total digits are required for fixed-point numbers, or drop some of the least significant digits if more than 15 total digits are required for floating-point numbers. Character values are changed by padding the shorter field with blanks.

%MICSEC (date/time-argument)
%MICSEC accepts a date/time argument and returns the microsecond part of the value. The date/time argument can be a timestamp (field or literal), a timestamp duration (field or literal), a character field that contains the external form of a timestamp, or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must be 14 digits followed by a decimal point and 6 digits.

%MIN (numeric-or-string-or-date/time-argument ...)
%MIN accepts one or more character-string, DBCS-string, numeric, or date/time arguments, and returns the smallest value from the list. Date/time arguments are arguments of type *DATE, *TIME, or *TIMESTP, or arguments that are date, time, or timestamp durations. String arguments must be no longer than 256 bytes.

If only one argument is specified, this function returns the minimum value of its argument for the group of records defined on the GRPFLD parameter, and the returned value has the same attributes as the argument. If no records are selected, the result is the null value. If the single argument is a date duration, time duration, or timestamp duration, then the returned value is a packed decimal number (*DEC) with 8 digits and 0 precision (date duration), 6 digits and 0 precision (time duration), or 20 digits and 6 precision (timestamp duration). When a single argument is used, it must be a field name or an expression (not a literal). %MIN with only one argument is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

If multiple arguments are specified, %MIN returns the minimum value of all the arguments. All arguments must be either character-string, DBCS-string, numeric, or date/time values. This function calculates the minimum value of the first two arguments, and then continues to determine the minimum value of the previous result and the next successive argument. The final result is determined by the value change rules described below.

If an argument has different attributes than the previous one, the two values are changed to identical attributes and the operation continues. This change uses packed decimal numbers if both values are fixed-point numeric values, or floating-point numbers if either value is a floating-point number. The change for fixed-point numeric values aligns the decimal points and pads with zeros. Numeric type change may truncate fractional digits if more than 31 total digits are required for fixed-point numbers, or may drop some of the least significant digits if more than 15 total digits are required for floating-point numbers. Character values are changed by padding the shorter field with blanks.

%MINUTE (date/time-argument)
%MINUTE accepts a date/time argument and returns the minute part of the value. The date/time argument can be a time or timestamp field, a time duration or timestamp duration (either field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 6 digits and 0 precision for time duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 6 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

%MONTH (date/time-argument)
%MONTH accepts a date/time argument and returns the month part of the value. The date/time argument can be a date or timestamp field, a date duration or timestamp duration (field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 8 digits and 0 precision for date duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 8 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

%NODENAME (integer-argument)
%NODENAME accepts an integer-argument which is used to identify a file that has been specified on the FILE parameter. The argument must be greater than 0 and less than or equal to the number of files specified on the file parameter. The %NODENAME function returns the RDB name for the record retrieved. The returned value is of type *VCHAR of length 18.

Find the node name for every record of the EMPLOYEE table.

Example:
  OPNQRYF
     FILE((CORPDATA/EMPLOYEE))
     FORMAT(FNAME)
     MAPFLD((NODENAME '%NODENAME(1)'))

Join the EMPLOYEE and DEPARTMENT tables, select the employee number (EMPNO) and determine the node from which each record involved in the join originated.

Example:
 OPNQRYF
  FILE((CORPDATA/EMPLOYEE) (CORPDATA/DEPARTMENT))
  FORMAT(FNAME)
  JFLD((EMPLOYEE/DEPTNO DEPARTMENT/DEPTNO *EQ))
  MAPFLD((EMPNO 'EMPLOYEE/EMPNO')
         (NODENAME1 '%NODENAME(1)')
         (NODENAME1 '%NODENAME(2)'))

Join the EMPLOYEE and DEPARTMENT tables, select all records of the result where the records of the two tables are on the same node.

Example:
 OPNQRYF
  FILE((CORPDATA/EMPLOYEE) (CORPDATA/DEPARTMENT))
  FORMAT(FNAME)
  JFLD((1/NODENAME1 2/NODENAME2 *EQ))
  MAPFLD((NODENAME1 '%NODENAME(1)')
         (NODENAME2 '%NODENAME(2)'))
%NODENUMBER (integer-argument)
%NODENUMBER accepts an integer-argument which is used to identify a file that has been specified on the FILE parameter. The argument must be greater than zero and less than or equal to the number of files specified on the file parameter. The %NODENUMBER function returns a 4-byte binary number (*BIN4) with 10 total decimal digits and no fraction digits. The returned value will be the node number of the record selected.

If the argument identifies a non-distributed file, the value zero is returned.

For OPNQRYF the node number from the secondary file where the outer or exception join is performed will be returned.

If CORPDATA.EMPLOYEE was a distributed file, then the node number for each record and the employee name would be returned.

Example:
  OPNQRYF
     FILE((CORPDATA/EMPLOYEE))
     FORMAT(FNAME)
     MAPFLD((NODENAME '%NODENUMBER(1)')
            (LNAME '1/LASTNAME'))
%NONNULL (argument ...)
%NONNULL accepts a list of two or more arguments and returns the first non-null value from the list. The items in the argument list can be fields or literal values of any type. The type of the returned value is that of the item selected from the list.
Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('%NONNULL(fld1 fld2 0) > 0')

The above example selects records from the file where either field FLD1 or field FLD2 contains a non-null value that is greater than zero. If both FLD1 and FLD2 were null, the %NONNULL function specified in this example would return '0' because of the constant '0' passed as the third argument. If any field is DBCS-graphic, all fields must be DBCS-graphic.

%NOT (string-argument)
%NOT accepts a character or hexadecimal string argument and returns a string that is the bit-wise 'NOT' (logical not) of the argument. The returned value is a string of type *HEX with the same length as the argument.

%OR (string-argument ...)
%OR accepts two or more character-string arguments and returns a string that is the bit-wise 'OR' (logical inclusive or) of the arguments. This function takes the first argument string, ORs it with the next string, and then continues to OR each successive argument with the previous result. If an argument is encountered that is shorter than the previous result, it is padded with blanks. The final result is a string with the same length as the longest argument. If any of the arguments are variable-length, the maximum length is used as the length of the argument.

%PARTITION (integer-argument)
%PARTITION accepts an integer-argument which is used to identify a file that has been specified on the FILE parameter. The argument must be greater than 0 and less than or equal to the number of files specified on the file parameter. The partition function returns a 4-byte binary number (*BIN4) with 10 total decimal digits and no fraction digits. The returned value will be the partition number of the record.

If the argument identifies a non-distributed file then a value of zero will be returned.

Find the PARTITION number for every row of the EMPLOYEE table. This could be used to determine if there is data skew.

Example:
  OPNQRYF FILE((CORPDATA/EMPLOYEE))
     FORMAT(FNAME)
     MAPFLD((PART1 '%PARTITION(1)'))

Select the employee number (EMPNO) from the EMPLOYEE table for all records where the partition number is equal to 100.

Example:
  OPNQRYF
     FILE((EMPLOYEE))
     QRYSLT('%PARTITION(1) *EQ 100')

Join the EMPLOYEE and DEPARTMENT tables, select all records of the result where the records of the two tables have the same partition number

Example:
  OPNQRYF
     FILE((CORPDATA/EMPLOYEE) (CORPDATA/DEPARTMENT))
     FORMAT(FNAME)
     JFLD((1/PART1 2/PART2 *EQ))
     MAPFLD((PART1 '%PARTITION(1)')
     (PART2 '%PARTITION(2)'))
%SECOND (date/time-argument)
%SECOND accepts a date/time argument and returns the seconds part of the value. The date/time argument can be a time or timestamp field, a time duration or timestamp duration (either field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 6 digits and 0 precision for time duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 6 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

%SIN (numeric-argument)
%SIN accepts a numeric argument and returns the sine of the argument. The argument must be specified in radians. %SIN and %ASIN are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%SINH (numeric-argument)
%SINH accepts a numeric argument and returns the hyperbolic sine of the argument. The argument must be specified in radians.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%SQRT (numeric-argument)
%SQRT accepts a numeric argument and returns the square root of the argument.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%SST (string-argument start-position-expression <length-expression>)
%SST and %SUBSTRING accept a character, hexadecimal, DBCS, or graphic string, a starting position expression, and an optional length expression as arguments. They return a substring of the string argument that is of the same type and CCSID as the string argument and has length equal to the value specified by the length-expression.

Single-byte substringing is done when these functions (%SST and %SUBSTRING) are used for DBCS data. The shift-out and shift-in characters may be lost, which produces unusual results. The result of the DBCS substring operation is the DBCS-open type.

The string argument can be a fixed- or variable-length character, hexadecimal, DBCS, or graphic field or an expression which evaluates to a fixed- or variable-length character, hexadecimal, DBCS, or graphic string.

The values derived from expressions for the second and third arguments must be valid integers. The second argument must have a value between 1 and the length attribute (or maximum length of a variable-length field) of the first argument, and the third argument must have a value between 1 and the length attribute (or maximum length of a variable-length field) of the first argument.

If an argument is DBCS-graphic, the second and third arguments must also be specified as DBCS-graphic characters, not bytes.

If an expression is given for the second or third arguments, the expression must be enclosed in parentheses.

If the expressions evaluate to variable-length results, no validation of the range of these expressions is guaranteed and errors may occur during input/output processing.

The maximum value allowed for the third argument (length) is 32766 except for DBCS-graphic, which is 16383. However, if the third operand is represented by an expression, this causes the result to be variable-length. Thus, the value of the expression cannot exceed 32740 except for DBCS-graphic, which cannot exceed 16370.

The user can omit the third argument. If the third argument is not specified and the first argument is:

  • fixed-length, the default value for the third argument is LENGTH(argument_1) - value_for_argument_2 + 1
  • variable-length, the default value for the third argument is the maximum of 0 and LENGTH(argument_1) - value_for_argument_2 + 1
  • variable-length with a length less than the value for argument_2, the default value for the third argument is zero and the result is the empty string.

Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('field1 =      %SST(field2 (numfld1+3)
     (numfld1+numfld2))')
%STDDEV (numeric-argument)
%STDDEV accepts a numeric argument and returns the standard deviation of its argument for the group of records defined by the GRPFLD parameter. The argument must be a field name or an expression (not a literal). If no records are selected, the result is the null value. Otherwise, the returned value is a double-precision floating-point number (*FLT8). %STDDEV is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

%STRIP(string-argument <strip-character> <strip-function>)
%STRIP accepts a character-, DBCS-, or graphic- string argument, an optional strip character, and an optional strip function as arguments. It returns a result string with the strip character removed from the string argument as specified by the strip function.

The string argument can be a literal, a fixed or variable-length character, hexadecimal, DBCS, or graphic field, or an expression which evaluates to a fixed- or variable-length character, hexadecimal, DBCS, or graphic string.

The strip character must be a single character, enclosed in apostrophes, with a data type compatible to the source string. The default is a single SBCS space for character data, DBCS-open, and DBCS-either, a single DBCS space for DBCS-only data, and a single graphic space for graphic data.

The strip function can be one of three functions:

*LEAD
Remove leading strip character(s)
*TRAIL
Remove trailing strip character(s)
*BOTH
Remove both leading and trailing strip character(s)

The default strip function is *BOTH.

The return value is a variable-length string with the same type, CCSID, and maximum length as the string argument. If the source string or strip character is null, the result is null.

Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('%STRIP(fld '.' *TRAIL) = 'Mr')
%SUBSTRING (string-field-name start-position length)
%SUBSTRING performs the same operation as %SST. See the %SST description for more information.

%SUM (numeric-argument)
%SUM accepts a numeric argument and returns the sum of all the values for its argument in the group of records defined on the GRPFLD parameter and must be enclosed in parentheses. The argument must be a field name or an expression (not a literal).

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. If no records are selected, the result is the null value. Otherwise,

  • If the argument is floating-point number, the returned value is a double-precision floating-point number (*FLT8).
  • If the argument is a binary number with zero-precision, the returned value is *BIN4.
  • If the argument is a binary number with nonzero precision or a fixed-point number, the returned value is a packed decimal number (*DEC) with 31 total digits and as many fractional digits as the argument.
  • If the argument is of type date duration, time duration, or timestamp duration, the returned value is a double-precision floating-point number (*FLT8).

%SUM is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

%TAN (numeric-argument)
%TAN accepts a numeric argument and returns the tangent of the argument. The argument must be specified in radians. %TAN and %ATAN are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The return value is a double-precision floating-point number (*FLT8).

%TANH (numeric-argument)
%TAN accepts a numeric argument and returns the hyperbolic tangent of the argument. The argument must be specified in radians. %TANH and %ATANH are inverse operations.

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. Arguments of these types can be specified either as fields or literal values. The returned value is a double-precision floating-point number (*FLT8).

%TIME (date/time-argument)
%TIME accepts a date/time argument and returns a time. The date/time argument can be a time or timestamp field, a character or hexadecimal field containing the external form of a time, or a time literal. The returned value is of type *TIME.

%TIMESTP (date/time-argument date/time-argument)
%TIMESTP accepts one or two date/time arguments and returns a timestamp.

  • If only one date/time argument is specified, it must be a timestamp (field or literal), or a character or hexadecimal field containing the external form of a timestamp.
  • If both arguments are specified,

    1. The first date/time argument must be a date (field or literal), or a character or hexadecimal field containing the external form of a date.
    2. The second date/time argument must be a time (field or literal), or a character or hexadecimal field containing the external form of a time.

The returned value is of type *TIMESTP.

%USER
%USER does not support any arguments. It returns the user profile name of the job in which the query is running. The returned value is of type variable-length character (*VCHAR) with a maximum length of 18.
Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('field = %USER')
%VAR (numeric-argument)
%VAR accepts a numeric argument and returns the variance of its argument for the group of records defined by the GRPFLD parameter. The argument must be a field name or an expression (not a literal).

The following argument types are treated as numeric values: date duration, time duration, and timestamp duration. If no records are selected, the result is the null value. Otherwise, the returned value is a double-precision floating-point number (*FLT8). %VAR is an aggregate function that is used for a nongrouping field in a query that uses the grouping function.

%XLATE (string-argument qualified-table)
%XLATE accepts a character-string argument and the name of a table object (*TBL), and returns a string that is the value of the first argument translated by using the contents of the table. The returned value is a string with the same length and CCSID as the first argument.

The second argument must be a simple or qualified table object name. If no library name is specified, *LIBL is used to find the table.

%XOR (string-argument...)
%XOR accepts two or more character-string arguments and returns a string that is the bit-wise 'XOR' (logical exclusive or) of the arguments. This function takes the first argument string, XORs it with the next string, and then continues to XOR each successive argument with the previous result. If an argument is encountered that is longer than the previous result, the previous result is padded with blanks before the XOR operation. If any of the arguments is variable-length, the maximum length is used as the length of the argument. The final result is a string of type *HEX with the same length as the longest argument.

%YEAR
%YEAR accepts a date/time argument and returns the year part of the value. The date/time argument can be a date or timestamp field, a date duration or timestamp duration (field or literal), or a numeric field or literal. The returned value is of type *BIN4.

A numeric field argument must be defined as packed decimal (*DEC) with 8 digits and 0 precision for date duration or packed decimal (*DEC) with 20 digits and 6 precision for timestamp duration. A numeric constant argument must have 8 digits followed by a decimal point, or 14 digits followed by a decimal point and 6 digits.

Restricted Built-in Functions

The following built-in function is supported only as the second operand of the 'equal' or 'not-equal' relational operators specified on the QRYSLT or GRPSLT parameter.

%NULL
%NULL accepts no arguments. It is used to select or omit records based on whether or not a field in the record contains a null value.
Example:
  OPNQRYF
     FILE(library/file)
     QRYSLT('charfld = %NULL')

This query would select all the records where 'charfld' contains the null value.

The following three built-in functions are supported only as the second operand of the 'equal' relational operator specified on the QRYSLT or GRPSLT parameter.

%RANGE (low-value high-value)
%RANGE is used to identify the lower and upper boundaries for the value of a field or expression. %RANGE must be specified as the right side of a relation whose operator is equal. The low-value and high-value argument must be field names, character strings, or numeric literals, to match the type of field or expression specified as left side of the relation. For example, to select only records where the numeric field NBRFLD has a value ranging from 10 through 20, specify:
'nbrfld = %RANGE(10 20)'

If the low-value argument is greater than the high-value argument, the relation produces a logical value of 'false'.

%VALUES (allowed-value...)
%VALUES is used to identify a list of allowed values for a field or expression. %VALUES must be specified as the right side of a relation whose operator is equal. The allowed-value arguments must be character string or numeric literals, to match the type of the field or expression specified as the left side of the relation. For example, to select only records where the second character of field CHARFLD has a value that is one of the values 'A', 'E', 'I', 'O', or 'U', specify the following:
'%SST(charfld 2 1) =   %VALUES(''A'' ''E'' ''I'' ''O'' ''U'')'
%WLDCRD (''pattern-string'' ''wild-characters''])
%WLDCRD is used to specify a pattern that performs a wildcard scan of the character or hexadecimal field or string expression (except for expressions made up of a single character-string literal) that must be specified as the left side of the relation. %WLDCRD must be specified as the right side of a relation whose operator is equal. The pattern-string argument must be a character-string, DBCS, or graphic literal, to match the left side of the relation. The wild-characters argument is an optional parameter that specifies what 'wildcard' characters are used in the pattern-string.

If specified for character data only (no DBCS data), the wild-characters argument must be a character-string literal of exactly two characters. The first character is the value that matches any single character in the search string. The second character is the value that matches a substring of any zero or more characters. The two characters must not be the same, but there is no requirement that either character appear in the pattern-string. If the wild-characters argument is omitted, the default is for an underline ('_') to match any single character and an asterisk ('*') to match a substring of any zero or more characters.

If the wild-characters argument is specified for DBCS data only (no character data), the argument must be a double-byte character-string literal of exactly two double-byte characters. The first double-byte character is the value that will match any one double-byte character in the search string. The second double-byte character is the value that will match a substring of any zero or more characters. The two double-byte characters must not be the same, but there is no requirement that either character appear in the pattern string. If the wild-characters argument is omitted, the default is for a DBCS underline to match any one double-byte character and a DBCS asterisk to match a substring of any zero or more double-byte characters.

If the wild-characters argument is specified for both character and DBCS data, in addition to the previous rules, the argument must first contain a single-byte character-string literal (two single-byte characters), then a double-byte character string (two double-byte characters).

In this case, the first character matches any single-byte character in the character string, the second character matches a substring of any number of single-byte or double-byte characters. The first double-byte character matches any double-byte character in the character string. The second double-byte character matches a substring of any number of single-byte or double-byte characters.

The following example selects only records where the character field CHARFLD contains a 'T', followed by any two characters and an 'E', appearing anywhere in the field.

'charfld = %WLDCRD(''*T__E*'')'

Note: The asterisks at the start and end of the pattern-string are required to allow the 'T' and 'E' to appear somewhere other than the first and last positions in the field:

To select only records where the character field CHARFLD starts with the string 'ABC', followed by one or more other characters and then followed by the string 'XYZ' (but not necessarily at the end of the field), specify the following:

'charfld = %WLDCRD(''ABC_*XYZ*'')'

To select only records where the second character of field CHARFLD is an asterisk ('*'), the last character is an underline ('_'), and the letter 'M' appears somewhere in between, specify the following:

'charfld = %WLDCRD(''#*.M._'' ''#.'')'

Error messages for OPNQRYF

*ESCAPE Messages

CPF2115
Object &1 in &2 type *&3 damaged.
CPF2169
Job's sort sequence information not available.
CPF2619
Table &1 not found.
CPF3BCC
Language identifier &1 not valid.
CPF3BC6
Sort sequence &1 not valid.
CPF3BC7
CCSID &1 outside of valid range.
CPF3BC8
Conversion from CCSID &1 to CCSID &2 is not supported.
CPF3BC9
Conversion from CCSID &1 to CCSID &2 is not defined.
CPF3BDD
Sort sequence &1 not valid for UCS2 data.
CPF3FC0
Language identifier is not valid.
CPF4174
OPNID(&4) for file &1 already exists.
CPF8133
Table &4 in &9 damaged.
CPF9801
Object &2 in library &3 not found.
CPF9802
Not authorized to object &2 in &3.
CPF9803
Cannot allocate object &2 in library &3.
CPF9807
One or more libraries in library list deleted.
CPF9808
Cannot allocate one or more libraries on library list.
CPF9810
Library &1 not found.
CPF9812
File &1 in library &2 not found.
CPF9813
Record format &3 in file &1 not found.
CPF9815
Member &5 file &2 in library &3 not found.
CPF9820
Not authorized to use library &1.
CPF9822
Not authorized to file &1 in library &2.
CPF9826
Cannot allocate file &2.
CPF9830
Cannot assign library &1.
CPF9899
Error occurred during processing of command.

*STATUS Messages

CPI4011
Query running. &2 records selected, &1 processed.
CPI4301
Query running.
CPI4302
Query running. Building access path for file &1 in &2.
CPI4303
Query running. Creating copy of file &1 in &2.
CPI4304
Query running. &1 records selected. Selection complete.
CPI4305
Query running. Sorting copy of file *N in *N.
CPI4306
Query running. Building access path from file &1 in &2.
CPI4307
Query running. Building hash table from file &1 in &2.