Version:

MarketplaceSupport

Database connectors

For database backends (JDBC-accessible), the change detection options are:

  • Changelog – This connector type relies on a database table that contains all changes that have occurred on the base tables (that the RadiantOne virtual view is built from). This typically involves having triggers on the base tables that write into the log/changelog table. However, an external process may be used instead of triggers. The connector picks up changes from the changelog table. If you need assistance with configuring triggers on the base tables and defining the changelog table, see Create scripts to generate triggers and changelog table.

  • Timestamp – This connector type has been validated against Oracle, SQL Server, MySQL, MariaDB, PostgreSQL, Snowflake, and Apache Derby. The database table must have a primary key defined for it and an indexed column that contains a timestamp/date value. This value must be maintained and modified accordingly for each record that is update1.

    For Oracle databases, the timestamp column type must be one of the following: TIMESTAMP, DATE, TIMESTAMP WITH TIME ZONE, `TIMESTAMP WITH LOCAL TIME ZONE1.

    For SQL Server database, the timestamp column type must be one of the following: SMALLDATETIME, DATETIME, DATETIME2

    For MYSQL or MariaDB databases, the timestamp column type must be one of the following: TIMESTAMP, DATETIME

    For PostgreSQL databases, the timestamp column type must be one of the following: TIMESTAMP, timestamp without time zone (equivalent to timestamp), TIMESTAMPTZ, timestamp with time zone (equivalent to timestamptz)

    For Snowflake, the timestamp column type must be: TIMESTAMPNTZ

    For Derby databases, the timestamp column type must be: TIMESTAMP

    The DB Timestamp connector leverages the timestamp column to determine which records have changed since the last polling interval. This connector type does not detect delete operations. If you have a need to detect and propagate delete operations from the database, you should choose a different connector type like DB Changelog or DB Counter.

  • Counter - This connector type is supported for any database table that has an indexed column that contains a sequence-based value that is automatically maintained and modified for each record that is added/updated. This column must be one of the following types: BIGINT, DECIMAL, INTEGER, or NUMERIC. If DECIMAL or NUMERIC are used, they should be declared without numbers after dot: DECIMAL(6,0) not as DECIMAL(6,2). The DB Counter connector leverages this column to determine which records have changed since the last polling interval. This connector type can detect delete operations as long as the table has a dedicated "Change Type" column that indicates one of the following values: insert, update, delete. If the value is empty or something other than insert, update, or delete, an update operation is assumed.


DB changelog

RadiantOne can generate the SQL scripts which create the configuration needed to support the DB Changelog Connector. The scripts can be generated in the Main Control Panel. The following scripts are generated and can be download from Main Control Panel > Settings > Configuration > File Manager. The are located in the /work/sql folder.

  • create_user.sql - Creates the log table user and the log table schema.
  • create_capture.sql - Creates the log table and the triggers on the base table.
  • drop_capture.sql - Drops the triggers and the log tabl1. Note: for some databases the file is empty.
  • drop_user.sql - Drops the log table user and schem1. Note: for some databases the file is empty.

Connector configuration

This section describes generating and executing the scripts in the Main Control Panel > Global Sync tab. The following steps assume the database backend has a changelog table that contains changed records that need to be propagated to destinations. The changelog table must have two key columns named RLICHANGETYPE and RLICHANGEID. RLICHANGETYPE must indicate insert, update or delete, dictating what type of change was made to the record. RLICHANGEID must be a sequence-based, auto-incremented INTEGER that contains a unique value for each record. The DB Changelog connector uses RLICHANGEID to maintain a cursor to keep track of processed changes.

If you need assistance with configuring triggers on the base tables and defining the changelog table, see Create scripts to generate triggers and changelog table.

To configure DB Changelog connector:

  1. From the Main Control Panel > Global Sync Tab, select the topology.
  2. On the right, select the sync pipeline to configure.
  3. Select a Capture component and the configuration displays.
  4. Select DB Changelog from the Connector Type drop-down list.
  5. Indicate the user name and password for the connector's dedicated credentials for connecting to the log table. If you do not have the user name and password, contact your DBA for the credentials.
  6. Enter the log table name using the proper syntax for your database (e.g. {USER}.{TABLE}_LOG).

DB Changelog Connector Configuration

  1. Select Save.
  2. A message is displayed that asks if you want to apply the scripts to configure the log table immediately or not. You can also download the scripts to the local machine. Configuration to Apply SQL Script Automatically or Not
  3. To apply now, select OK. Otherwise, select NO.
  1. After the capture connector is configured, configure the transformation in the pipeline.

Log table name syntax

Proper syntax for the Log Table Name must include both the schema name and the table name separated with a period. Values for this property may contain quote marks as required by the database. In most cases, the double quote mark (") is used, but some databases use a single quote (') or back quote (`). The following examples explain the property's syntax and usage.

Example 1:

For Postgres, if the schema is rli_con, and log table name is test_log, the property should be one of the following.

rli_con.test_log

Or with optional quoting:

"rli_con"."test_log"

Example 2:

For SQL Server, if the schema is RLI_CON, and log table name is TEST_LOG, the property should be one of the following.

RLI_CON.TEST_LOG

Or with optional quoting:

"RLI_CON"."TEST_LOG"

Example 3:

If schema and/or table name contain mixed-case characters, they must be quoted. For example, if the schema is Rli_Con, and log table name is Test_Log, the property should be as follows.

"Rli_con"."Test_log"


DB timestamp

The following steps assume your backend database table has a primary key defined and contains a timestamp column. The timestamp column name is required for configuring the connector. The timestamp column database types supported are described in the Database connectors section.

  1. From the Main Control Panel > Global Sync Tab, select the topology on the left.
  2. On the right, select the sync pipeline to configure.
  3. Select a Capture component and the configuration displays.
  4. Select DB Timestamp from the Connector Type drop-down list.
  5. Indicate the column name in the database table that contains the timestamp. An example is shown below. DB Timestamp Connector Configuration
  6. Select Save.
  7. You can configure connector properties in the Advanced Properties section.
  8. After the capture connector is configured, configure the transformation.

DB counter

The following steps assume your database backend table contains an indexed column that contains a sequence-based value that is automatically maintained and modified for each record that is added, updated or deleted. The DB Counter connector uses this column to maintain a cursor to keep track of processed changes. The counter column database types supported are described in the Database connectors section.

  1. From the Main Control Panel > Global Sync Tab, select the topology on the left.
  2. On the right, select the sync pipeline to configure.
  3. Select the Capture component and the configuration displays.
  4. Select DB Counter from the Connector Type drop-down list.
  5. Enter a value in the Change Type Column field. This value should be the database table column that contains the information about the type of change (insert, update or delete). If the column does not have a value, an update operation is assumed.
  6. Enter the column name in the database table that contains the counter. An example is shown below.
  7. Select Save
  8. You can configure connector properties in the Advanced Properties section.
  9. After the capture connector is configured, configure the transformation in the pipeline.

DB Counter Connector Configuration


Database connector failover

This section describes the failover mechanism for the database connectors.

The database connectors leverage the failover server that has been configured for the data source. When you configure a data source for your backend database, select a failover database server from the drop-down list. The failover server must be configured as a RadiantOne data source. See the screen shot below for how to indicate a failover server for the Data Sources from the Main Control Panel.

Configuring Failover Servers for the Backend Database

If a connection cannot be made to the primary server, the connector tries to connect to the failover server configured in the data source. If a connection to both the primary and failover servers fails, the retry count goes up. The connector repeats this process until the value configured in "Max Retries on Connection Error" is reached. There is no automatic failback, meaning once the primary server is back online, the connector does not automatically go back to it.

IN THIS PAGE