ODBC Destination
Applies to: SQL Server SSIS Integration Runtime in Azure Data Factory
The ODBC destination bulk loads data into ODBC-supported database tables. The ODBC destination uses an ODBC connection manager to connect to the data source.
An ODBC destination includes mappings between input columns and columns in the destination data source. You do not have to map input columns to all destination columns, but depending on the properties of the destination columns, errors may occur if no input columns are mapped to the destination columns. For example, if a destination column does not allow null values, an input column must be mapped to that column. In addition, columns of different types can be mapped, however if the input data is not compatible for the destination column type, an error occurs at runtime. Depending on the error behavior setting, the error will be ignored, cause a failure, or the row is sent to the error output.
The ODBC destination has one regular output and one error output.
The ODBC destination can use one of two access load modules. You set the mode in the ODBC Source Editor (Connection Manager Page). The two modes are:
Batch: In this mode the ODBC destination attempts to use the most efficient insertion method based on the perceived ODBC provider capabilities. For most modern ODBC providers, this would mean preparing an INSERT statement with parameters and then using a row-wise array parameter binding (where the array size is controlled by the BatchSize property). If you select Batch and the provider does not support this method, the ODBC destination automatically switches to the Row-by-row mode.
Row-by-row: In this mode, the ODBC destination prepares an INSERT statement with parameters and uses SQL Execute to insert rows one at a time.
The ODBC destination has an error output. The component error output includes the following output columns:
Error Code: The number that corresponds to the current error. See the documentation for your source database for a list of errors. For a list of SSIS error codes, see the SSIS Error Code and Message Reference.
Error Column: The source column causing the error (for conversion errors).
The standard output data columns.
Depending on the error behavior setting, the ODBC destination supports returning errors (data conversion, truncation) that occur during the extraction process in the error output. For more information, see ODBC Source Editor (Error Output Page).
There is no limitation on the number of ODBC destination components that can run in parallel against the same table or different tables, on the same machine or on different machines (other than normal global session limits).
However, limitations of the ODBC provider being used may restrict the number of concurrent connections through the provider. These limitations limit the number of supported parallel instances possible for the ODBC destination. The SSIS developer must be aware of the limitations of any ODBC provider being used and take them into consideration when building SSIS packages.
You must also be aware that concurrently loading into the same table may reduce performance because of standard record locking. This depends on the data being loaded and on the table organization.
You can log the calls that the ODBC source makes to external data providers. You can use this logging capability to troubleshoot the saving of data to external data sources that the ODBC destination performs. To log the calls that the ODBC destination makes to external data providers, enable the ODBC driver manager trace. For more information, see the Microsoft documentation on How To Generate an ODBC Trace with ODBC the Data Source Administrator.
You can configure the ODBC destination programmatically or through the SSIS Designer
For more information, see one of the following topics:
The Advanced Editor dialog box contains the properties that can be set programmatically.
To open the Advanced Editor dialog box:
- In the Data Flow screen of your SQL Server 2019 Integration Services (SSIS) project, right-click the ODBC destination and select Show Advanced Editor.
For more information about the properties that you can set in the Advanced Editor dialog box, see ODBC Destination Custom Properties.
Use the Connection Manager page of the ODBC Destination Editor dialog box to select the ODBC connection manager for the destination. This page also lets you select a table or view from the database
To open the ODBC Destination Editor Connection Manager Page
In SQL Server Data Tools, open the SQL Server 2019 Integration Services (SSIS) package that has the ODBC destination.
On the Data Flow tab, double-click the ODBC destination.
In the ODBC Destination Editor, click Connection Manager.
Select an existing ODBC connection manager from the list, or click New to create a new connection. The connection can be to any ODBC-supported database.
Click New. The Configure ODBC Connection Manager Editor dialog box opens where you can create a new connection manager.
Select the method for loading data to the destination. The options are shown in the following table:
Option | Description |
---|---|
Table Name - Batch | Select this option to configure the ODBC destination to work in batch mode. When you select this option the following options are available: |
Name of the table or the view: Select an available table or view from the list. This list contains the first 1000 tables only. If your database contains more than 1000 tables, you can type the beginning of a table name or use the (*) wild card to enter any part of the name to display the table or tables you want to use. Batch size: Type the size of the batch for bulk loading. This is the number of rows loaded as a batch |
|
Table Name - Row by Row | Select this option to configure the ODBC destination to insert each of the rows into the destination table one at a time. When you select this option the following option is available: |
Name of the table or the view: Select an available table or view from the database from the list. This list contains the first 1000 tables only. If your database contains more than 1000 tables, you can type the beginning of a table name or use the (*) wild card to enter any part of the name to display the table or tables you want to use. |
Click Preview to view up to 200 rows of data for the table that you selected.
Use the Mappings page of the ODBC Destination Editor dialog box to map input columns to destination columns.
The list of available input columns. Drag-and-drop an input column to an available destination column to map the columns.
The list of available destination columns. Drag-and-drop a destination column to an available input column to map the columns.
View the input columns that you selected. You can remove mappings by selecting <ignore> to exclude columns from the output.
View all available destination columns, both mapped and unmapped.
Use the Error Output page of the ODBC Destination Editor dialog box to select error handling options.
To open the ODBC Destination Editor Error Output Page
In SQL Server Data Tools, open the SQL Server 2019 Integration Services (SSIS) package that has the ODBC destination.
On the Data Flow tab, double-click the ODBC destination.
In the ODBC Destination Editor, click Error Output.
View the name of the data source.
Not used.
Select how the ODBC destination should handle errors in a flow: ignore the failure, redirect the row, or fail the component.
Select how the ODBC destination should handle truncation in a flow: ignore the failure, redirect the row, or fail the component.
View a description of the error.
Select how the ODBC destination handles all selected cells when an error or truncation occurs: ignore the failure, redirect the row, or fail the component.
Apply the error handling options to the selected cells.
You use the following options to configure how the ODBC destination handles errors and truncations.
The Data Flow task fails when an error or a truncation occurs. This is the default behavior.
The error or the truncation is ignored.
The row that is causing the error or the truncation is directed to the error output of the ODBC destination. For more information, see ODBC Destination.