Skip to content
Sadral edited this page Mar 29, 2016 · 8 revisions

PCTLoadData task -- <pct:data_load />

Description

Load tables data from plain .d files

Parameters

Attribute Description Type Requirement Default value
srcDir Source directory to load data from File Required No default value
srcFile Source file to load data from File Required No default value
tables Comma separated list of tables to load. Only used with srcDir attribute String Optional Blank means ALL
table Table name. Only used with srcFile attribute String Required No default value
callbackClass Callback class for the data load procedure. Only under OE 11.3+ String Optional No default value
errorTolerance Acceptable error percentage (must be between 0 and 100) Integer Optional 0

PCTLoadData inherits attributes from PCT and PCTRun.

Parameters as nested elements

Table

Loads a specific table. If no Table nodes are used, then PCTLoadData tries to load every table in dictionary.

Callback class

Callback class has to implement rssw.pct.ILoadDataCallback or extend rssw.pct.AbstractLoadDataCallback, and have a no-arguments constructor. The interface is :

  method public void beforeLoad(f as char).
  method public void afterLoad(f as char, logger as rssw.pct.LoadDataLogger).

An example class doing a full backup of the table before loading data and restoring data in case of failure is available here

Examples

Example 1

<PCTLoadData srcDir="data" dlcHome="${env.DLC}">
  <PCTConnection dbName="test" singleUser="true" />
</PCTLoadData>

Connects in single-user mode to test.db and loads each file from data directory in it

Example 2

<PCTLoadData srcDir="data" dlcHome="${env.DLC}">
  <PCTConnection dbName="test" singleUser="true" />
  <Table name="Table1" />
  <Table name="Table2" />
</PCTLoadData>

Connects in single-user mode to test.db and tries to load only Table1.d and Table2.d from data directory. If Table3 is present in dictionary, and Table3.d is present in data directory, then this file will be skipped.

Example 4

<PCTLoadData srcDir="data" dlcHome="${env.DLC}" tables="Table1,Table2">
  <PCTConnection dbName="test" singleUser="true" />
</PCTLoadData>

Shorter syntax doing the same as previous example

Example 5

<PCTLoadDataCallback srcFile="data/NewDataForTab1.d" table="Tab1" callbackProcedure="MyLogger" dlcHome="${env.DLC}">
  <PCTConnection dbName="test" singleUser="true" />
</PCTLoadDataCallback>

Connect in single-user mode to test.db, then load records from data/NewDataForTab1.d and using MyLogger class as a callback

Class MyLogger (which has to be found in propath) could be :

 method public override void afterLoad(f as char, logger as rssw.pct.LoadDataLogger):
  if logger:loadException or logger:bailed then copy-lob from logger:getErrors() to file "dataload.txt".
 end method.
Clone this wiki locally