CPYF
CPYF
CPYF
Purpose
The Copy File (CPYF) command copies all or part of a database or external device file to a
database or external device file. Copy operations can be done from physical, logical, diskette,
tape, inline, or DDM files to physical, diskette, tape, printer, or DDM files.
Some of the specific functions that can be performed by the CPYF command include the
following:
Copying one database file member, a set of members with a common generic name, or all
members in a database file. Many database file members can be copied to any valid tofile type except to more than one label on tape (FROMMBR and TOMBR parameters).
Copying one diskette file label identifier, a set of labels with a common generic name, or
all labels from a diskette file. Many diskette labels can be copied to any valid to-file type
except to more than one label on tape (FROMMBR and TOMBR parameters).
Adding records to an existing physical file member or replace the contents of a receiving
physical file member (MBROPT parameter).
o Comparing a specified value to one or more fields in each record. The record is
selected based on a logical expression over the field comparisons (INCREL
parameter).
Copying records between database files whose from-file and to-file record formats are
different, and converting records when the from-file and to-file are different file types
(source and data, FMTOPT parameter).
Inserting new sequence numbers and a zero date in the sequence number and date fields
of records copied to a source physical file (SRCOPT parameter).
Several other commands offer copy functions with a more specific set of parameters that are
tailored to the to-file or from-file. For more information, refer to the following command
descriptions:
CPYFRMDKT (Copy from Diskette)
CPYFRMTAP (Copy from Tape)
CPYSRCF (Copy Source File)
CPYTODKT (Copy to Diskette)
CPYTOTAP (Copy to Tape)
CPYFRMQRYF (Copy from Query File)
Table 1, Table 2, and Table 3, at the end of this command description, show the parameters that
are valid when copying from or to database files and device files.
Restrictions:
1. During the time a CPYF request is run, the file named on the TOFILE parameter may be
locked (similar to an *EXCL lock with no timeout) so that no access is possible.
2. When the CRTFILE(*YES) parameter is specified and the file copied (FROMFILE
parameter) has an associated trigger, the file created (TOFILE parameter) does not have
the associated trigger. The Add Physical File Trigger (ADDPFTRG) command must be
used to add a trigger to the file.
3. In multithreaded jobs, this command is not threadsafe when copying from or to multiple
database file members, device files (except SPOOL(*YES) print files), distributed files,
or DDM files of type *SNA. This command fails for distributed files that use relational
databases of type *SNA and DDM files of type *SNA. It is threadsafe ONLY when
copying from and to single database file members (local or DDM of type *IP) or
SPOOL(*YES) print files.
Required Parameters
FROMFILE
Specifies the qualified name of the database, inline data file, or device file that contains
the records being copied. A database file can be a physical or logical file. A device file
can be a diskette file or tape file.
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 name of the file that contains the records to be copied.
TOFILE
Specifies the qualified name of the file that receives the copied records.
Note: A device file can be a diskette file, tape file, or printer file. However: (1) If the from-file
and to-file are both diskette files, the to-file must be spooled (SPOOL(*YES) must be
specified on the Create Diskette File (CRTDKTF), Change Diskette File (CHGDKTF), or
Override Diskette File (OVRDKTF) command). (2) An externally described printer file
cannot be specified.
If the device file is a printer file or if TOFILE(*PRINT) is specified, shift-out shift-in
(SO-SI) character pairs are not added around the graphic data. OUTFMT(*HEX) can be
specified to print the data in hexadecimal format.
*PRINT: The data is copied to the IBM-supplied printer device file QSYSPRT and the
file is formatted according to the OUTFMT parameter.
The IBM-supplied printer file QSYSPRT may not be overridden to a different file name,
and it must have the RPLUNPRT(*YES) and CTLCHAR(*NONE) attributes.
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 qualified name of the physical file or device file that receives the
copied records. If no library qualifier is specified, *LIBL is used to locate the file.
However, if CRTFILE(*YES) is specified and the specified file cannot be found, the file
name must be qualified with a library name. When the physical to-file is created, it is
placed in the specified library.
Optional Parameters
FROMMBR
Specifies the database file member name, or the diskette or tape file label identifier in the
from-file, that is copied. A generic name or *ALL can be specified to copy many database
members or diskette file labels, but only a single file label identifier can be copied if the
from-file is a tape file. If the from-file is a spooled inline file, FROMMBR(*FIRST) is
required.
*FIRST: The first member (in the order of creation date) in a database from-file is
copied. If the from-file is a diskette or tape file, no label identifier is specified by the
copy operation when the file is opened. For diskette, a label identifier (LABEL
parameter) must be specified in the device file or on an OVRDKTF command.
FROMMBR(*FIRST) is required if the from-file is an inline file.
*ALL: All members of a database from-file, or all file label identifiers for a diskette
from-file are copied. FROMMBR(*ALL) is not valid if the from-file is a tape file or
inline data file.
If the to-file is a diskette or physical file, the data is copied to like-named to-file members
or labels (if TOMBR(*FROMMBR) is specified), or all the from-file members/labels are
copied to a single to-file member, diskette label or tape label. If the to-file is a printer file,
each member or label is copied to a separate spooled file. If TOFILE(*PRINT) is
specified, all the records are copied to a single print output file, and the records for each
member or label identifier copied starts on a new print page.
If one of the files copied from a diskette is continued onto another volume, all the files on
the continuation volume are also copied (or checked whether they should be copied if a
generic name is specified).
member-name: Specify the name of the database from-file member or diskette or tape
from-file label identifier of the file member being copied.
generic*-member-name: Specify a generic name to copy all database members that have
names with the same prefix, or all diskette data files with the same prefix label identifier.
Refer to the description of FROMMBR(*ALL) for more information about copying
many from-file members or label identifiers. A generic name is a character string of one
or more characters followed by an asterisk (*); for example, ABC*. The asterisk
substitutes for any valid characters. A generic name specifies all objects with names that
begin with the generic prefix for which the user has authority. If an asterisk is not
included with the generic (prefix) name, the system assumes it to be the complete object
name. See generic names for additional information.
TOMBR
Specifies the name of the file member that receives the copied records.
Note: If the to-file is a printer file, the TOMBR value must be either *FIRST or *FROMMBR.
If a member name or TOMBR(*FROMMBR) is specified on the CPYF command, or if a
to-member name is specified on an override and the member does not exist in the
physical to-file, a member is added to the file by the copy operation.
This parameter value is valid for both a single from-file member or label, and for many
from-file members or labels (specified by *ALL or a generic name for the FROMMBR
parameter).
Specifying the *FIRST value on the TOMBR parameter is not allowed if the to-file is a
physical file that has no members unless either a member name is specified in an
override, or CRTFILE(*YES) is specified and the to-file does not already exist. When a
physical file is created by the copy operation for the to-file and TOMBR(*FIRST) is
specified, the from-file file name is used as the member name in the created file.
*FIRST: The first member in the database to-file receives the copied records.
*FROMMBR: Corresponding from-file and to-file member names or label identifiers
are used. This parameter value is valid for both a single from-file member or label, and
for many from-file members or labels (specified by *ALL or a generic name for the
FROMMBR parameter). It is ignored if the to-file is a printer or if TOFILE(*PRINT) is
specified. If the to-file is a diskette or tape file, or if the to-file is a database file and there
is no member override, the TOMBR(*FROMMBR) value is valid only if the from-file is
a database, diskette, or tape file.
member-name: Specify the name of the physical to-file member, or diskette or tape to-file
label identifier, to receive the copied records. This parameter value is valid for both a
single from-file member or label, and for many from-file members or labels (specified by
*ALL or a generic name for the FROMMBR parameter). If a member with the specified
name does not already exist in the physical to-file, the copy operation attempts to add a
member with the specified name to the file.
MBROPT
Specifies whether the new records replace or are added to the existing records.
Note: If the records are being copied to an existing physical file, this parameter must specify
*ADD, *UPDADD, or *REPLACE. If the to-file does not exist but CRTFILE(*YES) is
specified, the copy operation assumes MBROPT(*ADD) for all records copied to the file
after it is created, regardless of the value specified on this parameter.
If *ADD or *UPDADD is specified and the from-file is empty (contains no records), the
copy operation completes normally. If *REPLACE is specified and the from-file is
empty, the copy operation ends abnormally.
*NONE: This parameter does not apply to this copy operation. When the to-file is an
existing physical file, MBROPT(*NONE) is not allowed; either *ADD, *UPDADD, or
*REPLACE must be specified to indicate whether records should be added or replaced in
each to-file member that is used.
*ADD: The system adds the new records to the end of the existing records.
*REPLACE: The system clears the existing member and adds the new records.
*UPDADD: The system updates the duplicate key records and adds the new records to
the end of the existing records.
CRTFILE
Specifies, when the CPYF command is used to copy from a physical file or logical file,
whether a physical file is created to receive the data if the to-file does not exist. If the to-
file already exists when the CPYF command is started, this parameter is ignored. If the
to-file is created, the text and public authority of the from-file are used.
*NO: The to-file must exist when the CPYF command is started. A physical file is not
created to receive the data.
*YES: If the to-file does not exist, a physical file is created with the name specified on
the TOFILE parameter. If the from-file is an SQL table, view, or index, that contains a
user defined type, datalink, or LOB field type, the physical file created will be an SQL
table. In all other instances the to-file created will be a database physical file that is not an
SQL table. In addition to the normal copy operation validity checks, the following special
conditions must all be true for the copy operation to create a to-file:
A library name must be specified on the TOFILE parameter. The default value,
*LIBL, is not allowed.
The user running the CPYF command must be authorized to add the file to the
TOFILE library, and must have operational authority to the CRTPF command.
A single record format must be used in the from-file. If the from-file is a logical
file with multiple formats, the RCDFMT parameter must specify a record format
name.
The members added to the physical file created by the copy operation have the names
specified by the TOMBR parameter. If TOMBR(*FIRST) is specified, the to-file member
has the same name as the from-file. The MBROPT parameter value is ignored when the
to-file is created, and records are added to the new file members.
PRINT
Specifies whether copied records, excluded records, or both, are printed. The records are
formatted according to the OUTFMT parameter value and written to the IBM-supplied
printer file QSYSPRT. QSYSPRT must be spooled (SPOOL(*YES) must be specified in
the device file or on the OVRPRTF command) when both copied and excluded records
are printed, or when either copied or excluded printouts are requested with
TOFILE(*PRINT), because separate printer files are opened for the printouts. If many
from-file members or labels are copied, all the members are included in the printer files
for copied or excluded records, and each member or label begins on a new print page.
If a selected range of records are requested to be copied using the FROMRCD, TORCD,
FROMKEY, TOKEY, or NBRRCDS parameters, then only the records copied or
excluded from that range are listed.
If the device file is a printer file, or if PRINT(*EXCLD) or PRINT(*COPIED) is
specified, SO-SI characters are not added around the graphic data. OUTFMT(*HEX) can
be specified to print the data in hexadecimal format.
*NONE: No copied, excluded, or error records are printed.
*EXCLD: Records excluded from the copy operation by the INCCHAR and INCREL
parameters are printed.
*COPIED: Copied records are printed.
*ERROR: The number of recoverable output error records specified on the ERRLVL
parameter are printed.
RCDFMT
Specifies, for a copy operation from a database file only, the name of the record format
that is copied. If the from-file is not a logical or physical file, RCDFMT(*ONLY) must
be specified.
*ONLY: The only record format in the from-file is copied. This value is required when
the from-file is not a logical or physical file. When the from-file is a logical file, this
value is valid only if the file has a single record format.
*ALL: All record formats in the logical from-file are used. This value is valid for a
physical file, and is also valid for a logical file even if the file has only a single record
format. If the logical file has many formats, RCDFMT(*ALL) is allowed only if the tofile is a device file or *PRINT, or if the to-file is a physical file and the FMTOPT
parameter value is specified as either *NOCHK or *CVTSRC.
record-format-name: Specify the name of the record format copied when the from-file is
a logical or physical file. A record format name is optional if the logical file has only a
single record format, but either a format name or *ALL must be specified if the from-file
has more than one record format. If the logical file is based on more than one physical
file member, only the data from the physical file members that are used to derive the
specified record format is copied.
FROMRCD
Specifies the record number of the first record in the from-file (or each from-file
member) copied. A FROMRCD record number is not valid if a value other than *NONE
is specified for the FROMKEY or TOKEY parameters, and is not allowed if the from-file
is a keyed logical file.
If the from-file is a physical file or a logical file with an arrival sequence access path, the
FROMRCD value is a relative record number that counts both the deleted and nondeleted
records that precede it. If the from-file is a device file or inline file, the FROMRCD value
is a record number that includes only nondeleted records (even for an I-format diskette
file).
If COMPRESS(*YES) is used, and the specified record in a database file member is
deleted, the copy operation starts with the first nondeleted record (if any) after the
specified record number.
*START: The copy operation begins with the first record in the file, as determined by the
access path or with the first record determined by the FROMKEY parameter value.
starting-record-number: Specify a record number, ranging from 1 through 4294967288,
that identifies the first record copied from the from-file. If both FROMRCD and TORCD
record number values are specified, the FROMRCD value must be less than or equal to
the TORCD value.
TORCD
Specifies the record number of the last record in the from-file (or each from-file member)
that is copied. A TORCD record number is not valid if a value other than *NONE is
specified for the FROMKEY or TOKEY parameters, or if a value other than *END is
specified for the NBRRCDS parameter, or if the from-file is a keyed logical file.
*END: Records are copied until the end-of-file condition is indicated by the from-file, or
until the amount is larger than the TOKEY record key value or the NBRRCDS maximum
number of records is reached.
ending-record-number: Specify a record number, ranging from 1 through 4294967288,
that identifies the last record copied from the from-file. If both FROMRCD and TORCD
record number values are specified, the FROMRCD value must be less than or equal to
the TORCD value. If an end-of-file condition is reached before this record number is
found, no error messages are issued.
FROMKEY
Specifies, when a file with a keyed access path is copied, that the key value of the first
record in the from-file (or each from-file member) is copied. This parameter is valid only
when a from-file is a keyed database file, and is not allowed if record number values are
specified for the FROMRCD or TORCD parameters.
If no record in the from-file member has a key that is a match with the FROMKEY value,
but there is at least one record with a key greater than the specified value, the first record
copied is the first record with a key greater than the FROMKEY value. If the specified
key value is greater than any record in the member, an error message is sent and the
member is not copied.
*NONE: The first record copied is not selected by key.
Keys With Single-Character String Values:
Specify both of the following elements to identify the key value of the first record copied
from the from-file.
Element 1: Number of Key Fields
number-of-key-fields: Specify the number of key fields used to locate the first record
copied. This value must be a number less than or equal to the total number of key fields
specified in the data description specification (DDS) for the from-file. If the number is
less than the total number of fields in the key, a partial key is used to locate the first
record copied.
Element 2: Key String Value
'key-value': Specify a character string (up to 256 characters) that specifies the actual key
value for the number of key fields specified by Element 1. The key string value specified
must be as long as the total length of all the key fields specified by Element 1, or
undesirable results may occur. If the key string specified is shorter than required for the
number of key fields used, the string must be padded on the right with zeros. The key
string value must be enclosed in apostrophes if it contains blanks or special characters,
and it may be specified in hexadecimal format, which is useful if the key contains packed
decimal or binary numeric fields, or is a variable-length character field. CCSID
conversions are not performed on character fields when a single string is specified.
Keys With A List Of Values:
Specify both of the following elements to identify values for the individual fields of the
key, which can be a composite key. This method is generally easier to use if the key
contains numeric fields.
Element 1: Build Keys For A List Of Values
*BLDKEY: Indicates that a list of values is provided for key fields (as opposed to a
single-character string value for all fields in the key). *BLDKEY is not valid if any value
in the list corresponds to a null-capable field.
Element 2: Key Field Value List
'key-field-value': Specify the list of values (up to 256 characters each) that is applied (in
order) to corresponding fields in the from-file key. The maximum number of values (up
to 50) allowed in the list is limited to the number of key fields defined in the data
description specifications (DDS) for the from-file. If fewer values are provided than the
total number of key fields defined for the file, a partial key is used to locate the first
record copied.
The values are converted from the displayed form to the type defined in the key field
definition. Values specified for character fields are converted from the current job CCSID
to the key field CCSID. When a DBCS graphic field is specified, the input string (DBCS
data) must be enclosed in SO-SI characters. The SO-SI characters are removed from the
input string and the remaining DBCS data is converted from the associated DBCS
CCSID of the current job to the DBCS CCSID of the DBCS graphic field. If a value is
specified for a character field that is shorter than the actual key field, the value is padded
on the right with blanks. A value specified for a numeric key field is converted to the type
and precision defined in the DDS for the key field. If a value is either too large for the
corresponding key field or cannot be converted to the type required for the key field, an
error message is sent, and the copy operation is not done. For date, time, or timestamp
fields, corresponding input values are converted to the format and separator form of the
from-file field. For variable-length fields, only specify the character data, not the 2-byte
length portion.
TOKEY
Specifies, when a file with a keyed access path is copied, the key value of the last record
in the from-file (or each from-file member) copied. This parameter is valid only for a
from-file that is a keyed database file, and is not allowed if record number values are
specified for the FROMRCD or TORCD parameters, or if a number of records is
specified for the NBRRCDS parameter.
If there is more than one record in a from-file member with a key that matches the
TOKEY value, all those records are copied. If no record in the from-file member has a
key that is a match with the TOKEY value, the last record copied is the last one (if any)
with a key value less than that of the specified key value.
If there are both ascending and descending fields in the file key, the first (the far left) key
field determines whether the copy operation uses an ascending or descending key test to
look for the last record to copy.
The user must specify one of the following:
*NONE
the record indicated by the value specified for the FROMRCD or FROMKEY parameter.
The TORCD or TOKEY parameters can be used only if NBRRCDS(*END) is specified.
This parameter controls the number of records that are copied after the selection value
(INCCHAR/INCREL) is applied. It does not control the number of records that are read.
*END: Records are copied until the end-of-file condition is indicated for the from-file,
unless either the TOKEY or TORCD parameter has been specified.
number-of-records: Specify the number of records, ranging from 1 to 4294967288, that
are copied to the to-file. Fewer records are copied if an end-of-file condition occurs
before the specified number of records have been copied.
INCCHAR
Specifies that records are copied or excluded based on the result of a comparison with a
character string value and the data in some position of either a field in the record or the
entire record. The comparison done can include searching the record or field for the
specified character string value. If INCCHAR is specified for a logical file with many
record formats and RCDFMT(*ALL) is specified, the character string is used for
selecting records from all the formats.
If both the INCCHAR and INCREL parameters are specified, a record is copied only if it
satisfies the requirements for both parameters.
*NONE: No character string value comparison is used to select which records are
copied.
Comparison Values: To specify the comparison that determines which records are
copied, four values must be entered. Either *RCD or the name of a field must be entered,
followed by the three values that control the comparison: starting position, operator, and
character string value. All records that satisfy the relationship specified by the four values
are copied to the to-file.
*RCD: The character string value is compared with the data at the specified starting
position in each record copied from the from-file.
*FLD: This value is the same as the *RCD value.
Element 1: Record Format Field Name
field-name: Specify the name of a field in the record format that is used to make the
comparison. The field must be defined as a character field in the data description
specification (DDS) for the from-file. When the from-file is a device or inline file, or
when the copy operation must process many record formats for a logical from-file (when
RCDFMT(*ALL) is specified), a field name cannot be specified (but *RCD is allowed).
Element 2: Field Record Starting Position
starting-position: Specify the position in the field or record where the comparison starts.
When a variable-length field name is specified, the position is in the data portion of the
variable-length field. For DBCS graphic fields, the position is the DBCS character
position. For any operator except *CT, the comparison is done for the length of the
character-string value (up to 256 maximum) specified on Element 4 of this parameter. For
the *CT operator, the field or record is scanned from the specified starting position to the
end of the field or record to determine whether it contains the specified character string.
The character string length plus the starting position must not be larger than the length of
the field (when a field name is specified) or a record (when *RCD is specified).
Element 3: Operator Value
operator: Specify the operator that indicates the relationship that must exist between the
specified portion of the record or field and the character string specified as the last part of
the INCCHAR parameter for the record copied to the to-file. The operators that are used
are:
*EQ
Equal
*GT
Greater than
*LT
Less than
*NE
Not equal
*GE
Greater than or equal
*NL
Not less than
*LE
Less than or equal
*NG
Not greater than
*CT
Contains
The value *IF must be specified as the first value in the first set of comparison values, if
there is only one set or several sets of comparison values. If more than one set of
comparison values are specified, either *AND or *OR must be specified as the first value
in each set after the first set of values. Each INCREL relational set must be enclosed in
parentheses.
*IF: Identifies the first field value relationship that must be satisfied before a record is
copied.
*AND: The field value relational groups on both sides of the *AND value must all be
satisfied before a record is copied.
*OR: If the field value relational group on either side of the *OR value is satisfied, the
record is copied.
Element 1: Field Name
field-name: Specify the name of the field compared. The field must exist in the from-file
record format, and may be defined as either character or numeric in the DDS for the file.
Element 2: Operator Value
operator: Specify the operator that indicates the relationship that must exist between the
field contents in the record and the field value specified as the fourth part of this INCREL
relation for this relation to be true. The operators that are used are:
*EQ
Equal
*GT
Greater than
*LT
Less than
*NE
Not equal
*GE
Greater than or equal
*NL
Not less than
*LE
Less than or equal
*NG
If the to-file is a data file, the from-file sequence number and date fields are
dropped, and the source data part of each from-file record is copied to the to-file,
as described for FMTOPT(*NOCHK).
If the to-file is a source file, sequence number and date fields are appended, and
the from-file record data is copied to the source data part of each to-file record, as
described for FMTOPT(*NOCHK). The SRCOPT and SRCSEQ parameters are
used to control the sequence numbers created in the to-file. Null values are
ignored and no conversion of date/time data occurs.
Note: When either the from-file or the to-file is not a database file, FMTOPT(*CVTSRC) is not
required for copying from a source file to a data file or from a data file to a source file.
Sequence number and date fields are appended or dropped automatically, depending on
the file types. If the to-file is a source physical file, the SRCOPT and SRCSEQ
parameters can be used to control the sequence numbers created for records copied to the
to-file.
*MAP: Fields with the same name in the from-file and to-file record formats are copied,
and any fields in the to-file that do not exist in the from-file format are set to one of the
following:
The default value indicated by the DFT value in the data description specification
(DDS) for the to-file.
If *MAP is specified, *DROP can also be specified. Mapped fields may have different
starting positions in the from-file and to-file record formats.
If *MAP is specified and a valid conversion is defined between the from-file field CCSID
and the to-file field CCSID, the character data is converted to the to-file field CCSID.
If the from-file field CCSID or the to-file field CCSID is 65535, the character data is not
converted.
*MAP allows conversion of date/time data and the copying of null values.
*DROP: This value must be specified for field-level mapping if any of the field names in
the from-file record format do not exist in the to-file format. If *DROP is specified,
*MAP can also be specified. When *DROP is specified, all the field names that exist in
both record formats must have the same attributes and relative positions in the from-file
and to-file record formats, or *MAP must also be specified. Null values are copied if
*DROP is valid.
*CVTFLOAT: This value is specified when CPYF processes each floating point field
identified by the external description of the output database physical file and convert it
from System/370 hexidecimal format to the IEEE format used by iSeries 400 computers.
*NULLFLAGS: This value is specifed when CPYF takes the byte following each field
identified as being nullable by the external description of the output file, and use it as a
flag to indicate if the corresponding input field is null. If the byte is blank ('40'X) or
contains '00'X, the data is considered to be not null. Any other value for the flag causes
the corresponding input field data to be ignored and the output value set to null.
Note: If *CVTFLOAT or *NULLFLAGS is specified and the input file is externally described,
the input file external description will not be used in doing the mapping of the copied
data. If *CVTFLOAT or *NULLFLAGS is specified, any other value is ignored (unless
both are specified). TOFILE must be an externally described physical data file. The
following parameter values cannot be specified when *CVTFLOAT or *NULLFLAGS is
specified:
A value other than default for CRTFILE (unless the TOFILE already exists
causing *YES to be ignored), FROMKEY, TOKEY, INCCHAR, INCREL,
SRCOPT, and SRCSEQ
Attention:
*CVTFLOAT and *NULLFLAGS must only be used for conversion of data to iSeries
400 format, and they must be used correctly to avoid possible data corruption.
Note: Additional information is available in the File Management topic in the Information
Center.
SRCOPT
Specifies, only for copying to a source physical to-file, whether new sequence numbers
are inserted in the sequence number fields, and whether the date fields are set to zero. If
*SEQNBR is specified, the SRCSEQ parameter gives the values that control the new
sequence numbers created in the records copied to each to-file member.
*SAME: The value does not change.
*SEQNBR: New source sequence numbers are inserted in the records copied to the tofile. The new sequence numbers are controlled by the SRCSEQ parameter value. This
value is valid only if the to-file is a source physical file. If *SEQNBR is specified,
*DATE can also be specified.
*DATE: The source date field is set to zero in the records copied to the to-file. This value
is valid only if the to-file is a source physical file. If *DATE is specified, *SEQNBR can
also be specified.
SRCSEQ
Specifies, only when SRCOPT(*SEQNBR) is also specified, the sequence number that is
given to the first record copied to the to-file, and what increment value is used to
renumber all other records copied. This parameter allows the copied file to have as many
as 999 999 records with unique sequence numbers. If SRCOPT(*SEQNBR) is specified,
but SRCSEQ is not specified, SRCSEQ(1.00 1.00) is assumed; the copied records are
renumbered sequentially beginning with 1.00, and the whole number increment of 1 is
used.
If SRCOPT(*SEQNBR) is specified and the maximum sequence number value of
9999.99 is reached, then all remaining records copied to the to-file member also have a
sequence number value of 9999.99.
Element 1: Starting Value
1.00: The first source record copied to the to-file has a sequence number of 0001.00.
starting-value: Specify a value ranging from 0000.01 through 9999.99 that is the
sequence number of the first source record copied to the to-file. A whole number of no
more than four digits and/or a fraction of no more than 2 digits is specified. If the starting
value contains a fraction, a decimal point must be used. Examples are .01 and 3250.4. (If
a value has a fraction of .00, such as 5000.00, it is specified without the fraction; either
5000 or 5000.00 is valid.)
Element 2: Increment Value
1.00: The copied source records are renumbered in the to-file with whole number
increments of 1. (1.00, 2.00, 3.00, ...)
increment-value: Specify a value ranging from 0000.01 through 9999.99 that is used as
the increment value for renumbering all source records copied after the first record. A
whole number of no more than four numbers and/or a fraction of no more than two
numbers can be specified. If the increment value contains a fraction, a decimal point must
be used. For example, if SRCSEQ(5000 10) is specified, the first record copied to the file
is numbered 5000.00, the second is 5010.00, the third is 5020.00, and so forth. If
SRCSEQ(1 .25) is specified, the copied records are numbered 1.00, 1.25, 1.50, 1.75,
2.00, and so forth.
OUTFMT
Specifies, if TOFILE(*PRINT) is specified, whether the copied records are printed in
character or hexadecimal format.
Note: This parameter is used only when TOFILE(*PRINT) is specified or the PRINT parameter
specifies *EXCLD, *COPIED, or both. This parameter has no effect on the printed output
when the to-file is a program-described printer file. The OUTFMT parameter is ignored
when the copy operation does not need to produce a formatted printer file.
*CHAR: Records are printed in character format only.
*HEX: Records are printed in both character format and hexadecimal format.
ERRLVL
Specifies the maximum number of recoverable read or write errors for the file that are
tolerated during the copy operation for a single database from-file member or tape fromfile label identifier. This parameter is ignored if the from-file is not a physical, logical, or
tape file and the to-file is not a physical file.
0: If any recoverable error occurs, the copy operation ends at the file member in which
the error occurs.
*NOMAX: No maximum number of errors is specified, and all recoverable errors are
tolerated. The copy operation continues regardless of the number of recoverable errors
found.
number-of-errors: Specify a value that specifies the maximum number of recoverable
errors that is allowed in each from-file member or label that is copied. If one more error
occurs than the value specified here, the copy operation is ends.
COMPRESS
Specifies whether the to-file contains a compressed form of the from-file. Compression
occurs when deleted records in the from-file are not copied to the to-file.
COMPRESS(*NO) is used to copy both deleted and nondeleted records only when the
from-file and to-file are both physical files. If MBROPT(*ADD) is specified with
COMPRESS(*YES), deleted records that existed in the to-file member before the copy
operation are not compressed.
*YES: The records copied to the to-file are compressed. Deleted records that exist in the
from-file are not copied to the to-file. Only nondeleted records are copied, and they are
renumbered consecutively in the to-file. That is, the relative record numbers of all
nondeleted records that occur after the first deleted record in the from-file are different in
the to-file. No physical record data, such as source sequence numbers, is changed by the
copy operation as a result of specifying COMPRESS(*YES). If from-file is deletecapable and the to-file is nondelete-capable, COMPRESS(*YES) must be specified.
*NO: Both the deleted and nondeleted records are copied to the to-file. If the from-file is
a database file that is copied in arrival sequence, the relative record numbers in the fromfile are not changed in the to-file if MBROPT(*REPLACE) is also specified. If the fromfile is a database file that is copied in keyed sequence (no deleted records are contained in
an access path), COMPRESS(*NO) is ignored.
Note: If the from-file is a keyed physical file and a record number value is specified for either
the FROMRCD or TORCD parameters, the from-file is copied in arrival sequence;
therefore, the COMPRESS parameter determines whether deleted records are copied. If
COMPRESS(*NO) is specified, the default value must be used for the INCCHAR and
INCREL parameters.
Table 1. Valid Parameters for Copying from or to Database Files (CPYF Command)
Physical1
Parameter From
FROMFILE X
TOFILE
FROMMBR X
TOMBR
MBROPT
CRTFILE X3
PRINT
X4
RCDFMT
FROMRCD X
TORCD
X
FROMKEY X
TOKEY
X
NBRRCDS X
INCCHAR X
INCREL
X
FMTOPT
X
SRCOPT
SRCSEQ
OUTFMT X4
ERRLVL
X
To
Logical1
From2
X
X
X
X
X
X3
X4
X
X
X
X4
X
X3
X4
X
X5
X5
X
X
X
X
X
X
X4
X
COMPRESS X6
Note:
X6
If the to-file does not exist before the copy operation begins, and the from-file is either a
physical or logical file, CRTFILE(*YES) can be specified to allow the copy operation to
create a physical file for the to-file.
4
A program-described printer file can be specified for the to-file to create a printout that
has no special formatting or page headings, or TOFILE(*PRINT) can be used to create a
formatted printout. PRINT(*EXCLD) or PRINT(*COPIED) may be specified to create a
formatted printout for any copy operation. When a printout is requested (by either
TOFILE(*PRINT) or by the PRINT parameter), the OUTFMT parameter specifies
whether the data is printed in character form or both character and hexadecimal form.
5
The FROMRCD and TORCD parameter values are valid for a from-file that is a logical
file if it has only an arrival sequence access path (no keyed access path).
6
Cannot copy from a delete capable file to a file that is not delete capable unless
COMPRESS(*YES) is specified.
Table 2. Valid Parameters for Copying from Device Files (CPYF Command)
Parameter
FROMFILE
FROMMBR
PRINT
FROMRCD
TORCD
NBRRCDS
INCCHAR
OUTFMT
ERRLVL
Note:
Diskette
X1
X
X2
X
X
X
X
X2
Tape
X
X
X2
X
X
X
X
X2
X
Inline Data
X
X2
X
X
X
X
X2
If both the from-file and to-file are diskette files, the to-file must be spooled
(SPOOL(*YES) is specified on CRTDKTF, CHGDKTF, or OVRDKTF command).
2
A program-described printer file can be specified for the to-file to create a printout that
has no special formatting or page headings, or TOFILE(*PRINT) can be used to create a
formatted printout. PRINT(*EXCLD) or PRINT(*COPIED) may be specified to create a
formatted printout for any copy operation. When a printout is requested (by either
TOFILE(*PRINT) or by the PRINT parameter), the OUTFMT parameter specifies
whether the data is printed in character form or both character and hexadecimal form.
Table 3. Valid Parameters for Copying to Device Files (CPYF Command)
Parameter
TOFILE
TOMBR
PRINT
OUTFMT
Note:
Diskette
X2
X
X1
X1
Tape
X
X
X1
X1
Printer1
X
X1
X1
A program-described printer file can be specified for the to-file to create a printout that
has no special formatting or page headings, or TOFILE(*PRINT) can be used to create a
formatted printout. PRINT(*EXCLD) or PRINT(*COPIED) may be specified to create a
formatted printout for any copy operation. When a printout is requested (by either
TOFILE(*PRINT) or by the PRINT parameter), the OUTFMT parameter specifies
whether the data is printed in character form or both character and hexadecimal form.
2
If both the from-file and to-file are diskette files, the to-file must be spooled
(SPOOL(*YES) is specified on CRTDKTF, CHGDKTF, or OVRDKTF command).
Examples for CPYF
The following examples of the CPYF command show the type(s) of files that are copied, and the
function provided by various parameters.
Example 1: Physical File to Physical File
CPYF FROMFILE(PERSONNEL/PAYROLL)
TOFILE(TESTPAY/PAYROLL) MBROPT(*ADD)
CRTFILE(*YES) ERRLVL(10)
This command copies all of the records in the physical file named PAYROLL in the
PERSONNEL library to the file PAYROLL in the TESTPAY library. If the from-file contains
more than one member, only the first member is copied. If TESTPAY/PAYROLL does not exist,
it is created before the records are copied and a member with the same name as the from-file is
added to TESTPAY/PAYROLL to receive the copied records.
Because MBROPT(*ADD) is specified, the copied records are added to any existing records in
the to-file member. Because RCDFMT(*NONE) is assumed, the to-file TESTPAY/PAYROLL
must have the same record format as the from-file. If the to-file (TESTPAY/PAYROLL) is
created by the copy operation, it will have the same record format and access path as the fromfile (PERSONNEL/PAYROLL). If more than ten recoverable errors occur during the copy
operation, the operation ends.
If FROMMBR(*ALL) and TOMBR(*FROMMBR) had also been specified, all of the members
in the from-file would be copied to corresponding members (having the same names) in the tofile. For each from-member that has no corresponding to-member, a member is added to the tofile and all the records in the from-member are copied to the new member. For each to-member
that already exists, only new records are added to the member. No updates are made to existing
records on any type of copy operation. If the to-file contains members for which there are no
corresponding members in the from-file, the to-file contains more members than the from-file
after the copy operation.
If more than ten recoverable errors occur within a member being copied, the copy operation ends
at that point, and remaining members are not copied. ERRLVL(*NOMAX) can be specified to
tolerate all recoverable errors, so the copy operation does not end no matter how many
recoverable errors occur in a particular file member.
Example 2: Physical File to Physical File
CPYF FROMFILE(PERSONNEL/EMP1)
TOFILE(PERSONNEL/VACLEFT)
FROMMBR(VAC) MBROPT(*REPLACE)
FROMKEY(1 X'0008872F') TOKEY(1 X'0810199F')
INCREL((*IF VAC *GT 5.0)) FMTOPT(*MAP *DROP)
In this example, the to-file (VACLEFT) is an existing physical file, but its record format differs
from that of the physical file named EMP1, which is being copied. Both files are in the
PERSONNEL library. The from-file contains employee records and has a key (employee
number). The records selected in the from-file are those with employee numbers ranging from
008872 through 810199. Only records for employees with more than five days of vacation
(VAC) are mapped to the receiving file. Records are selected from member VAC, and they
replace existing records in the first member of file VACLEFT.
Because the key for the file is a packed decimal number, the FROMKEY and TOKEY values
must be specified as hexadecimal strings, and the leading zeros and hexadecimal sign are
required in the value. An alternative way of specifying the same key value range follows:
This command copies five records from member TOTSALES of logical file SALES (in library
DEPTS) to member MARCH in the physical file YTDSALES (in library DEPTS). If member
MARCH does not exist, it is created and added to the to-file automatically by the copy operation.
Only records from the logical file SALES in library DEPTS that use record format AA are
copied, and they are copied to YTDSALES, which has the same format. After the copy
operation, the MARCH member contains only five nondeleted records, because all records in
that member are first cleared, then only the data in the first five records (in keyed sequence) in
the TOTSALES member are copied to it.
Example 5: Device File to a Physical File
CPYF FROMFILE(QDKT) TOFILE(QGPL/QCLSRC)
FROMMBR(PAY*) TOMBR(*FROMMBR)
MBROPT(*REPLACE) SRCOPT(*SEQNBR)
SRCSEQ(1 .25)
This command copies records from the generic set of diskette labels with names that start with
the characters PAY. They are copied to like-named members in source file QCLSRC in the
QGPL library. Even though the to-file is a source file, a diskette file (QDKT) defined as
FILETYPE(*DATA) is used as the from-file, because QDKT is more efficient than a device file
defined as FILETYPE(*SRC). For each label copied, the sequence number of the first record is
1.00 and is incremented by .25 for each subsequent record. The source date field is automatically
set to zeros.
Example 6: Physical File to the Printer
CPYF FROMFILE(TEMPFILE) TOFILE(*PRINT)
FROMMBR(EMP1) FROMKEY(1 448762)
NBRRCDS(20) OUTFMT(*HEX)
This command copies records from member EMP1 in the file named TEMPFILE. The records
are employee records. One key field, the employee number, is used to search the record keys.
Twenty records, starting with employee number 448762, are copied to the IBM-supplied printer
file QSYSPRT and listed in both character and hexadecimal format. The IBM-supplied printer
file is indicated by coding TOFILE(*PRINT).
Example 7: Physical File to a Device File
CPYF FROMFILE(PERSONNEL/PAYROLL)
TOFILE(DISK1) FROMMBR(VAC1)
INCCHAR(NAME 1 *CT SMITH)
The name, type, length, null capability, date, or time format, separators, and decimal positions
attributes of each field on the format that is specified are used. The file is created without key
fields and is an arrival sequence physical file.
In some cases, the OPNQRYF command changes the format of the format that is specified on the
new to-file. The new to-file format may become null-capable when the OPNQRYF command
uses one of the following grouping functions:
%STRDEV
%VAR
%SUM
%AVG
%MIN
%MAX
Note: A new to-file with a changed format has a format level identifier that is different from the
format level identifier that is specified on the OPNQRYF command.
File Management
Authorities, user profiles, and file capabilities of the to-file created by Copy File (CPYF)
When the Copy File (CPYF) command creates the local physical file, the from-file gives the
created to-file all the authorities of the from-file. These authorities include public, private, and
authorization lists. When CPYFRMQRYF creates the local physical file, the authorities given are
of the first file that is specified on the FILE parameter of the corresponding Open Query File
(OPNQRYF) command. The authorities include public, private, and authorization lists.
In both cases, the owner of the created to-file is the user profile running the copy command. The
user running the copy command inherits *ALL authority to the object. This is true unless the user
is a member of a group profile and has OWNER(*GRPPRF) specified for the profile.
If you specify OWNER(*GRPPRF), the group profile becomes the owner of the to-file. In this
case, if the user profile running the copy command does not have authority to add a member or
write data to the new file, the copy command fails.
The created to-file does not maintain the file capabilities of the from-file. The to-file allows
update, delete, read, and write operations, regardless of whether the from-file allowed these
operations. Following are special considerations for the new to-file:
If the number of records copied into a member is greater than the maximum size of the
created to-file, the to-file is extended without intervention by the system operator.
If the from-file is an SQL table, view, or index, the created to-file will be a physical file
that is not an SQL table. However, when the from-file contains LOBs, datalinks, or userdefined types, the created to-file is an SQL table.
If
the
from-file
has
a
trigger
program
associated
with
it,
the CPYF and CPYFRMQRYF commands do not copy the trigger information to the tofile when the CRTFILE parameter is used.
If you create a new file (CRTFILE(*YES)) from a file with constraints, the constraint
definitions do not copy to the new file.
If you create a new file (CRTFILE(*YES)) from a file with user-defined functions, the
user-defined functions do not copy to the new file.