data:image/s3,"s3://crabby-images/443b4/443b49d90341289cc9800d3fb640b8a722f1b92d" alt="SQL Server 2017 Integration Services Cookbook"
上QQ阅读APP看书,第一时间看更新
How to do it...
- In the CustomLogging.dstx package, navigate to the dft_dbo_CustomLogging by double-clicking on the Data Flow task. Click on the path (blue arrow) between the ole_src_SELECT_1and the ole_dst_dbo_CustomLogging transform to select it. Right-click on it and select Delete to delete it.
data:image/s3,"s3://crabby-images/895a2/895a2844609bfb342acec524d56bef321ff3555e" alt=""
- Drag and drop a derived column transform from the SSIS Toolbox onto the data flow. Link it to the ole_src_SELECT_1 and double-click on it to open the derived column transformation. As shown in the following screenshot, do the following:
- Derived Column Name: DateToConvert
- Derived Column: leave it as <Add as new column>
- Expression: Type 1600-01-00. This is not a valid date; it will cause an error and that's precisely what we want.
- Click on OK when finished.
data:image/s3,"s3://crabby-images/476b6/476b605e86831831d183459d516ac7bce8e8450f" alt=""
- Rename the derived column der_AddDate.
- Now, drag and drop a data conversion transform onto the dataflow task. Attach it to the der_AddDate derived column created previously and double-click on it to open the Data Conversion Transformation Editor. Enter the values as shown in the following screenshot:
- Input Column: Check the column DateToConvert in the Available Input Columns.
- Output Alias: Change it to DateConverted.
- Data Type: Select date [DT_DATE] from the drop-down list.
It is also shown in the following screenshot:
data:image/s3,"s3://crabby-images/21369/2136940bdbd13e4b18d039e374eeb92ceb9871f7" alt=""
- The Data Conversion Transformation Editor should now look like the following screenshot. Click on the Configure Error Output... button.
data:image/s3,"s3://crabby-images/e2658/e2658d284ac237c3d06a5677194b4e0a4a364917" alt=""
- You will get a screen like the following screenshot. By default, the Error and Truncation errors will fail the component.
- Select both columns and from the drop-down list near Set this value to select cells, select Redirect row. Click Apply.
- You should now see that both column values are now set to Redirect row.
-
- Click OK to close the editor and rename the transform as dcnv_DateConverted.
data:image/s3,"s3://crabby-images/a9de1/a9de110fa9ca081c2fed3ba483037c4d42c77c00" alt=""
- Now, bring an audit transform from other transforms onto the dataflow task. The following steps detail what's in the following screenshot:
- Attach the Data Conversion Error Output (red path or arrow) to it.
- Right-click on the error path and select Enable Data Viewer from the menu that appears.
data:image/s3,"s3://crabby-images/b6c7d/b6c7da34aaf63f4faf2d7e66c4a66d20e26304c5" alt=""
As we did before in the Customized logging level recipe, select all the transforms and click on Make Same Width from the Layout toolbar. From the Format menu, select Format Auto Layout à Diagram to format the data flow task objects properly.
- Your data flow task should look like the following screenshot. Now, right-click anywhere in the background of the data flow task and select Execute Task from the menu.
data:image/s3,"s3://crabby-images/877a5/877a58e960a8657d241bd5b9d9a3b64740e7a82b" alt=""
- You should see a data viewer like the following screenshot:
data:image/s3,"s3://crabby-images/e4e86/e4e860abd7c740bcd59557603528469fce850237" alt=""
It is explain in as follows:
- The DateToConvert is the column we tried to convert.
- The second column is the ErrorCode, an internal code to SSIS.
- The third column is the ErrorColumn which is a lineage ID that SSIS assigns to all columns in the data flow task.
- The ErrorCode - Description column gives us the reason for the error.
- The ErrorColumn - Description gives us the column that failed to be converted (DateConverted).