Using ODBC and ADO.Net to Connect SSIS to DB2
I needed to connect SSIS to a DB2 database via ODBC today and learned something worth blogging about: There are different ways to use ODBC connections in SSIS. It seems I learn some cool, new, flexible function about SSIS every time I take it out for a spin!
I had already installed the IBM DB2 client for Windows and tested the ODBC connection it created, so I knew I had good credentials and could access the data I wanted. It's important to check this before proceeding.
I created a new project to test different connection flavors.
I right-clicked in the Connection Managers workspace and selected "Create Connection."
Next, I selected ODBC as the type of connection:
data:image/s3,"s3://crabby-images/b9ad1/b9ad1100d9b80a73c2e7fdd8e72f9ad6cb596654" alt=""
I then clicked the New button on the "Configure ODBC Connection Manager":
data:image/s3,"s3://crabby-images/96451/96451e9a0a23f3ba2c4f5652a5846a2f85dad7d9" alt=""
The Connection Manager opened and I entered the name of the test server's data source name; followed by my login credentials:
data:image/s3,"s3://crabby-images/9259b/9259bc0503e6b1e95400e5d2f0f14cf2b73ab092" alt=""
I then clicked the "Test Connection" button. It failed because I mistyped my password, displaying the following dialog:
data:image/s3,"s3://crabby-images/d81a6/d81a666a860c934c253907ef5d2363c653c2bf58" alt=""
When I corrected my password, the test succeeded:
data:image/s3,"s3://crabby-images/9b74b/9b74b01b759800da037f4fb52239bd0064cbd953" alt=""
I clicked OK to close the Connection Manager...
data:image/s3,"s3://crabby-images/477a4/477a4a016845a2b4d451fbf23b92ec5904a1a06c" alt=""
...and the clicked OK again to close the "Configure ODBC Connection Manager" dialog. A new connection appeared in the connection managers workspace:
data:image/s3,"s3://crabby-images/04068/04068a42cd451a58fef90c0cd094e98dec97b7ff" alt=""
I like to rename the connection to something more descriptive, so I appended a dot and the connection type (i.e. ".ODBC") to the connection name:
data:image/s3,"s3://crabby-images/ba2d4/ba2d41067fb3b6c9d650de45d62d1a37f7db3f4d" alt=""
Next I created a new ADO.Net connection:
data:image/s3,"s3://crabby-images/69a7c/69a7c9c515a70afe46fd3afee78260427450122f" alt=""
When the dialog appeared, I selected the "Odbc Data Provider" provider type:
data:image/s3,"s3://crabby-images/045a4/045a4525026e50e7012614acd9ed3c0220c2c4a5" alt=""
I then supplied the DSN and credentials as before:
data:image/s3,"s3://crabby-images/46c35/46c351429a15dc87a0bac236b729364baca48bb8" alt=""
After configuring the connection, I clicked OK and dragged a Data Flow onto the workspace:
data:image/s3,"s3://crabby-images/338ac/338ac376a8e74c189ff31bfda6d94e2fbf9a3f08" alt=""
I next opened the Data Flow and dragged a DataReader Source onto the data flow:
data:image/s3,"s3://crabby-images/21c59/21c596cb8c01258c4659c46f4c85ccae33146d75" alt=""
I double-clicked the DataReader to edit it, and the Advanced Editor. I then toggled between the two connections, hitting the Refresh button to update the feedback:
data:image/s3,"s3://crabby-images/a3a7c/a3a7c67b41d9f731cc8f28a0479f35a69f3612b7" alt=""
When set to the ODBC connection, the DataReader cannot acquire a managed connection. I could not make the DataReader work under these conditions:
data:image/s3,"s3://crabby-images/2f392/2f392e78ad4fd683afac9923ea18691214da3cce" alt=""
When I changed the connection to the Ado.net connection and clicked the Refresh button, the feedback vanished, indicating the DataReader is prepared to use this connection object:
data:image/s3,"s3://crabby-images/f61fb/f61fbe9cf625bb65ff29ffccb9ff9dcfc1a7211a" alt=""
That's it! In sum, I was able to use the ODBC connection - but only through the ADO.Net connection.
:{> Andy
Technorati Tags: SSIS Sql Server DB2 Developer Community Richmond Virginia