设为首页 收藏本站
查看: 722|回复: 0

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

[复制链接]

尚未签到

发表于 2016-11-7 06:01:31 | 显示全部楼层 |阅读模式
1. 问题分析
1.1 验证环境
VS2005 TS SP1
SQL 2005 SP2 BI Studio
某企业客户提供的异常数据
1.2 问题场景
在某企业客户目前Informix数据当中存在很多小于1753-01-01的无效数据,而由于SQL 2005的DateTime 数据类型的数据域是从 1753 年 1 月 1 日到 9999 年 12 月 31 日,会导致从Informix通过SSIS向SQL 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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-296658-1-1.html 上篇帖子: sql server 2012附加数据库时出现错误"Error:5123"的解决办法 下篇帖子: sql server添加用户,关联到一个已存在的数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表