SQL Server Integration Service(SSIS)扩展开发自定义组件解决无效时间问题

1. 问题分析

1.1             验证环境

VS2005 TS SP1

SQL 2005 SP2 BI Studio

某企业客户提供的异常数据

1.2             问题场景

在某企业客户目前Informix数据当中存在很多小于1753-01-01的无效数据,而由于SQL 2005DateTime 数据类型的数据域是从 1753 1 1 日到 9999 12 31 ,会导致从Informix通过SSISSQL Server写入数据时出错。

 

1.3             解决思路

根据对问题的具体分析,给出以下几种解决办法:

1.从数据源清理根除无效数据;

       2.通过将目标数据表的数据类型设置成整型或字符型解决;

       3.通过编写包含IF逻辑判断子句的SQL语句解决;

       4.通过SSIS扩展脚本组件编写逻辑代码块解决;

       5.通过SSIS扩展开发可视化数据流组件来解决;

 

经过与某企业客户技术人员的讨论,决定采用对系统影响最小,不需改动数据库和SQL代码,不需编写逻辑代码块的第5种方式来解决,即开发SSIS扩展可视化数据流组件。

 

 

2. 解决步骤

2.1             组件安装

1.拷贝DateTimeLimiter.dll

C:/Program Files/Microsoft SQL Server/90/DTS/PipelineComponents

注:文件夹位置可能会因SQL安装位置而不同;

2.打开Visual Studio 2005 命令提示工具,输入:

gacutil.exe -iF "c:/Program Files/Microsoft Sql Server/90/DTS/PipelineComponents/DateTimeLimiter.dll"

3.打开SQL Server 2005 SSIS项目,选择并打开数据流任务

       从左侧工具栏中“选择项”对话框中选取“SSIS数据流项”中的时间转换组件(如图)

2.2             组件使用

1.从数据流转换栏目中找到“时间转换”组件,并拖拽到数据流任务中

2.使用方式与数据转换类似,可在数据源和数据目标之间完成日期数据项的1753问题修复

2.3             运行结果验证

测试对比结果:

 

未使用时间转换组件时:

1753-1-1,1.0,A,湖滨南路五龙大厦龙启阁603,0.0

1753-2-1,2.0,O,?0.0

1979-7-12,3.0,T,2227826 8800681,0.0

1752-1-1,4.0,C,湖滨南路五龙大厦龙启阁603,0.0

1752-12-31,5.0,H,2227826 8800681,0.0

使用时间转换组件后:

1753-1-1, 1.0,A,湖滨南路五龙大厦龙启阁603,0.0

1753-2-1, 2.0,O,?0.0

1979-7-12, 3.0,T,2227826 8800681,0.0

1753-1-1, 4.0,C,湖滨南路五龙大厦龙启阁603,0.0

1753-1-1, 5.0,H,2227826 8800681,0.0

 

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值