Version

    DB2BulkWriter

    Short Description
    Ports
    Metadata
    DB2BulkWriter Attributes
    Details
    Notes and Limitations
    Compatibility
    See also

    Short Description

    DB2BulkWriter loads data into DB2 database.

    [Important]When to use DB2BulkWriter

    This component requires installation and configuration of a database native client. The client must be running on the same machine as the database server. Due to this overhead, we recommend using this component only if you require significantly higher loading performance than with DatabaseWriter which should be used in typical scenarios.

    ComponentData outputInput portsOutput portsTransformationTransf. requiredJavaCTLAuto-propagated metadata
    DB2BulkWriterdatabase0-10-1
    no
    no
    no
    no
    no

    Ports

    Port typeNumberRequiredDescriptionMetadata
    Input0[1]Records to be loaded into the database.Any
    Output0
    no
    For information about incorrect recordsError Metadata for DB2BulkWriter

    [1]  If no file containing data for loading (Loader input file) is specified, the input port must be connected.

    Metadata

    DB2BulkWriter does not propagate metadata.

    Error Metadata cannot use Autofilling Functions.

    Table 55.2. Error Metadata for DB2BulkWriter

    Field numberField nameData typeDescription
    0<any_name1>integerThe incorrect record's number (records are numbered starting from 1).
    1<any_name2>integer

    The incorrect field's number (for delimited records), fields are numbered starting from 1 | offset of an incorrect field (for fixed-length records).

    2<any_name3>stringError message

    DB2BulkWriter Attributes

    AttributeReqDescriptionPossible values
    Basic
    File metadata 

    Metadata of an external file.

    The metadata must be delimited. Each column, except the last one, is followed by an identical, one char delimiter. The last delimiter following the last column is \n. Delimiter must not be a part of any field value.

     
    DatabaseyesThe name of the database into which records should be loaded. 
    Database tableyesThe name of the database table into which records should be loaded. 
    User nameyesDatabase user. 
    PasswordyesPassword for database user. 
    Load mode 

    Mode of the action performed when loading data.

    For more information, see Load mode.

    insert (default) | replace | restart | terminate
    Field mapping[1]

    Sequence of individual mappings ($CloverField:=DBField) separated by a semicolon, colon, or pipe. For more information, see Mapping of Clover Fields to DB Fields.

     
    Clover fields[1]

    The sequence of Clover fields separated by a semicolon, colon, or pipe. For more information, see Mapping of Clover Fields to DB Fields.

     
    DB fields[1]

    The sequence of DB fields separated by a semicolon, colon, or pipe. For more information, see Mapping of Clover Fields to DB Fields.

     
    Advanced
    Loader input file[2]

    Name of input file to be loaded, including path. For more information, see Loader input file.

     
    Parameters 

    All parameters that can be used as parameters by the load method. These values are contained in a sequence of pairs of the following form: key=value, or key only, (if the key value is the boolean true) separated from each other by a semicolon, colon, or pipe. If the value of any parameter contains the delimiter as its part, such value must be double quoted.

     
    Rejected records URL (on server) 

    The name of the file, including the path, on a DB2 server where rejected records will be saved. Must be located in the directory owned by the database user.

     
    Batch file URL 

    The URL of the file where the connect, load and disconnect commands for db2 load utility are stored. Normally, the batch file is automatically generated, stored in the current directory and deleted after the load finishes. If the Batch file URL is specified, the component tries to use it as is (generates it only if it does not exist or if its length is 0) and does not delete it after the load finishes.

    It is reasonable to use this attribute in connection with the Loader input file attribute, because the batch file contains the name of temporary data file which is generated at random, if not provided explicitly.

    The path must not contain white spaces.

     
    DB2 command interpreter 

    Interpreter that should execute script with DB2 commands (connect, load, disconnect). Its form must be the following: interpreterName [parameters] ${} [parameters]. This ${} expression must be replaced with the name of this script file.

     
    Use pipe transfer 

    By default, data from an input port is written to a temporary file and then it is read by the component. If set to true on Unix, data records received through the input port are sent to a pipe instead of a temporary file.

    false (default) | true
    Column delimiter 

    The first one char field delimiter from File metadata or the metadata on the input edge (if File metadata is not specified). A character used as a delimiter for each column in data file. The delimiter must not be contained as a part of a field value. The same delimiter can be set by specifying the value of the coldel parameter in the Parameters attribute. If Column delimiter is set, coldel in Parameters is ignored.

     
    Number of skipped records 

    The number of records to be skipped. By default, no records are skipped. This attribute is applied only if data is received through the input port; otherwise, it is ignored.

    0 (default) | 1-N
    Max number of records 

    The maximum number of records to be loaded into database. The same can be set by specifying the value of the rowcount parameter in the Parameters attribute.

    If rowcount is set in Parameters, the Max number of records attribute is ignored.

    all (default) | 0-N
    Max error count 

    The Maximum number of records after which the load stops. If the number is set explicitly and when it is reached, the process can continue in RESTART mode. In REPLACE mode, the process continues from the beginning. The same number can be specified with the help of warningcount in the Parameters attribute. If warningcount is specified, Max error count is ignored.

    all (default) | 0-N
    Max warning count The maximum number of printed error messages and/or warnings.999 (default) | 0-N
    Fail on warnings 

    By default, the component fails on errors. By switching the attribute to true, you can make the component fail on warnings. Background: when an underlying bulk-loader utility finishes with a warning, it is just logged to the console. This behavior is sometimes undesirable as warnings from underlying bulk-loaders may seriously impact further processing. For example, Unable to extend table space may result in not loading all data records to a database; hence not completing the expected task successfully.

    false (default) | true

    [1]  For more information about their relation, see Mapping of Clover Fields to DB Fields.

    [2]  If the input port is not connected, Loader input file must be specified and contain data. For more information, see Loader input file.

    Details

    DB2BulkWriter loads data into a database using a DB2 database client. It can read data through the input port or from an input file. If the input port is not connected to any other component, data must be contained in an input file that should be specified in the component. If you connect some other component to the optional output port, it can serve to log the information about errors. The DB2 database client must be installed and configured on localhost. The server and database must be cataloged as well.

    Mapping of Clover Fields to DB Fields

    • Field Mapping is Defined

      If a Field mapping is defined, the value of each Clover field specified in this attribute is inserted to such DB field to whose name this Clover field is assigned in the Field mapping attribute.

    • Both Clover Fields and DB Fields are Defined

      If both Clover fields and DB fields are defined (but Field mapping is not), the value of each Clover field specified in the Clover fields attribute is inserted to such DB field which lies on the same position in the DB fields attribute.

      The number of Clover fields and DB fields in both of these attributes must equal to each other. The number of either part must equal to the number of DB fields that are not defined in any other way (by specifying Clover fields prefixed by dollar sign, db functions or constants in the query).

      Pattern of Clover fields:

      CloverFieldA;...;CloverFieldM

      Pattern of DB fields:

      DBFieldA;...;DBFieldM

    • Only Clover Fields are Defined

      If only the Clover fields attribute is defined (but Field mapping and/or DB fields are not), the value of each Clover field specified in the Clover fields attribute is inserted to such DB field whose position in DB table is equal.

      Number of Clover fields specified in the Clover fields attribute must equal to the number of DB fields in DB table that are not defined in any other way (by specifying Clover fields prefixed by a dollar sign, db functions, or constants in the query).

      Pattern of Clover fields:

      CloverFieldA;...;CloverFieldM

    • Mapping is Performed Automatically

      If neither Field mapping, Clover fields, nor DB fields are defined, the whole mapping is performed automatically. The value of each Clover field of Metadata is inserted into the same position in the DB table.

      The number of all Clover fields must equal to the number of DB fields in the DB table that are not defined in any other way (by specifying Clover fields prefixed by a dollar sign, db functions, or constants in the query).

    Load mode

    • insert

      Loaded data is added to the database table without deleting or changing existing table content.

    • replace

      All data existing in the database table is deleted and new loaded data is inserted to the table. Neither the table definition nor the index definition are changed.

    • restart

      Previously interrupted load operation is restarted. The load operation automatically continues from the last consistency point in the load, build, or delete phase.

    • terminate

      Previously interrupted load operation is terminated and rolled back to the moment when it started even if consistency points had been passed.

    Loader input file

    Loader input file is the name of the input file with data to be loaded, including its path. Normally, this file is a temporary storage for data to be passed to dbload utility unless named pipe is used instead.

    Remember that a DB2 client must be installed and configured on localhost (see IBM data server clients and drivers overview and Installing IBM data server clients (Linux and UNIX)). The server and database must be cataloged as well.

    • If it is not set, a loader file is created in CloverDX or OS temporary directory (on Windows) or named pipe is used instead of a temporary file (on Unix). The file is deleted after the load finishes.

    • If it is set, a specified file is created. It is not deleted after data is loaded and it is overwritten on each graph run.

    • If the input port is not connected, the file must exist, must be specified and must contain data that should be loaded into the database. It is not deleted nor overwritten.

    Notes and Limitations

    DB2BulkWriter cannot write maps and fields.

    Compatibility

    VersionCompatibility Notice
    5.3.0DB2DataWriter was renamed to DB2BulkWriter.