Database Table Source

Centerprise Database Source provides the functionality to retrieve data from a database table. It also provides change data capture functionality to perform incremental reads and supports multi-way partitioning, which partition database table into multiple chunks and reads these chunks in parallel. This features brings about major performance benefits for database reads. Database source also enables you to specify a where clause and sort order to control the result set.

Video

In this article we will be discussing how to:

  1. Get Database Table Source object on the dataflow designer.
  2. Configure the Database Table Source object according to the required layout and settings.

We’ll also be discussing some best practices for using a Database Table Source object.

Getting Database Table Source

In this section, we’ll cover how to get Database Table Source object on the dataflow designer from the toolbox.

  1. To get a Database Table Source from the Toolbox, go to Toolbox > Sources > Database Table Source. If you’re unable to see the toolbox, go to View > Toolbox or press Ctrl + Alt + X.

    ../_images/116.png

  2. Drag-and-drop the Database Table Source object onto the designer.

    ../_images/28.png

    You can see that the dragged source object is empty right now. This is because we haven’t configured the object yet.

Configuring the Database Table Source

  1. To configure the Database Table Source object, right-click on its header and select Properties from the context menu.

    ../_images/34.png

    As soon as you’ve selected the Properties option from the context menu, a dialog box will open.

    ../_images/44.png

    This is where you can configure the properties for the Database Table Source object.

  2. The first step is to specify the Database Connection for the source object.

../_images/54.png

  • Put in the required credentials. You can also use the Recently Used drop-down menu to connect to a recently connected database.
  • You will find a drop-down list next to the Data Provider.

../_images/65.png

That is where you select the specific database provider to connect to and the following connection credentials will vary according to the provider selected.

  • Test Connection to make sure that your database connection is successful and click Next.
  1. Next, you will see a Pick Source Table and Reading Options screen. On this screen, you will select the table from the database that you have previously connected to, and configure the table from the given options.

    ../_images/74.png

    • From the Pick Table box, choose the table that you want to read the data from.

      ../_images/84.png

      Note: We will be using the Customers table in this case.

      ../_images/94.png

      • Once you pick a table, an icon will show up beside the Pick Table box.

        ../_images/104.png

        • View Data: You can view data in a separate window in Centerprise.

        ../_images/117.png

        • View Schema: You can view the schema of your database table from here.

        ../_images/123.png

        • View in Database Browser: You can see the selected table in the Database Source Browser in Centerprise.

        ../_images/134.png

    • Table Partition Options

      This feature substantially improves the performance of large data movement jobs. Partitioning is done by selecting a field and defining value ranges for each partition. At runtime, Centerprise generates and runs multiple queries against the source table and processes the result set in parallel.

      ../_images/144.png

      • Check on the Partition Table for Reading, if you want your table to be read in partitions.
      • You can specify the Number of Partitions.
      • Pick Key for the Partition box will let you choose the key field for partitioning the table.
      • If you have specific key values based on which you want to partition the table, you can use the option ***Specify Key Values (Separated by comma)***.
    • Favor Centerprise Layout is useful in the cases where your source database table layout has changed over time, but the layout built in Centerprise is static. And you want to continue to use your dataflows even with the updated source database table layout. You check this box and Centerprise will favor its own layout over the db layout.

      ../_images/154.png

    • Incremental Reads Options

      Database Table Source provides incremental read functionality based on the concept of audit fields. Incremental read is one of the three change data capture approaches supported by Centerprise. Audit fields are fields that are updated when a record is created or modified. Examples of audit fields include created date time, modified date time, and version number.

      Incremental read works by keeping a track of the highest value for the specified audit field. On the next run, only the records with value higher than the saved value are retrieved. This feature is useful in situations where two applications need to be kept in sync and the source table maintains audit field values for rows.

      ../_images/164.png

      • Select Full Load if you want to read the entire table.

      • Select Incremental Load Based on Audit Fields to perform an incremental read. Centerprise will start reading the records from the last read.

        ../_images/17-1570624010900.png

        • Checking on Perform full load on next run, will override the incremental load function from the next run onwards and will perform a full load on it.
        • Use Audit Field to compare when the last read was performed on the dataset.
        • Specify the path to the file in the File Path, that will store incremental transfer information.
  2. The next screen will show you a Layout Builder. On this screen, you can modify the layout of your database table.

    ../_images/183.png

    Note: By default, Centerprise reads the source layout.

    • If you want to delete a field from your dataset, click on the serial column of the row that you want to delete. The selected row will be highlighted in blue.

      ../_images/192.png

      Right-click on the highlighted line, a context menu will appear in which you will have the option to Delete.

      ../_images/203.png

      Selecting Delete will delete the entire row.

      ../_images/213.png

      The field is now deleted from the layout and won’t appear in the output.

      Note: Modifying the layout (adding or deleting fields) from the layout builder screen in Centerprise will not make any changes to the actual database table. The layout is only specific to Centerprise.

    • If you want to change the position of any field and want to move it below or above another field in the layout, you can do that by selecting the row and using Move up/Move down keys.

      Note: You will find the Move up/Move down icons, on the top left of the builder.

      ../_images/223.png

      For example: We want to move the Country field right below the Region field. We’ll select the row and use the Move up key to move the field from the 9th row to the 8th.

      ../_images/233.png

  3. After you’re done customizing the Layout Builder, click Next. You will be taken to a new screen -Where Clause. Here, you can provide a WHERE clause, which will filter the records from your selected database table.

    Note: If the wizard is left blank Centerprise will use the default values of the database table.

    ../_images/243.png

    • For instance, if you add a WHERE clause that selects all the customers from the country “Mexico” in the “Customers” table.

      ../_images/251.png

      Your output will be filtered out and only the records that satisfy the where condition will be read by Centerprise.

      ../_images/262.png

  4. Once you’ve configured the database table source object, click Next.

    ../_images/271.png

  5. A new screen -Config Parameters will open. Here, you can define parameters for the Database Table Source object.

    Parameters can provide easier deployment of flows by eliminating hardcoded values and provide an easier way of changing multiple configurations with a simple value change.

    ../_images/281.png

    Note: Parameters can be changed in the Config Parameters wizard page. Parameters left blank will use their default values assigned on the properties page.

  6. Click OK.

    ../_images/29.png

Your DatabaseSource object is now configured according to the changes you made.

../_images/30.png

You have successfully configured your Database Table Source object. The fields from the source object can now be mapped to other objects in a dataflow.

Best Practices for using Database Table Source

Get the Database Table from the Data Source Browser

  1. To get Database Table Source from the Data Source Browser, go to View > Data Source Browser or press Ctrl + Alt + D.

    ../_images/311.png

  2. A new window will open.

    ../_images/321.png

    You can see that the pane is empty right now. This is because we are not connected to any database source yet.

  3. To connect the browser to a database source, click on the first icon on the top left of the pane.

    ../_images/331.png

    • A Database Connection box will open.

      ../_images/341.png

      This is where you can connect your database from the browser.

    • You can either connect to a recently connected database or create a new connection.

      ../_images/35.png

      Note: In this case we will use one of our recent connections.

    • To create a new connection, first you select your Data Provider from the drop-down list.

      ../_images/36.png

      Note: We’ll be using the SQL Server in this case.

    • The next step is to fill in the required credentials. Also, to ensure that the connection is successfully made, Test Connection.

      ../_images/37.png

      Once you test your connection, a dialog box will open, which will indicate whether the test was successful or not.

      ../_images/38.png

      Click OK.

      ../_images/39.png

      Once you’ve connected the browser, your Data Source Browser will now have the databases that you have stored on your server.

      ../_images/40.png

  4. Select the database that you want to work with and then choose the table you want to use.

    Note: In this case we’ll be using the Northwind database and Customers table.

    ../_images/411.png

  5. Drag-and-drop Customers onto the designer in Centerprise.

    ../_images/421.png

    If you expand the dropped object, you will see that the layout for the source file is already built. You can even preview the output at this stage.

    ../_images/431.png

Database Table Options

../_images/441.png

Right-clicking on the Database Table Source will also display options for the Database Table.

  • Show in DB Browser - Will show where the table resides in the database in the Database Browser
  • View Table Data - Builds a Query and displays all the data from the table
  • View Table Schema - Displays the schema of the database table
  • Create Table - Creates a table on a database based on the schema