Read Registry Key in Script Task

上一篇谈到读取excel的时候,通过修改注册表值的办法来提高判断数据类型的准确性

http://blog.csdn.net/u012988208/article/details/52192049


但是,修复/重新安装office,安装AccessDatabaseEngine,都会造成TypeGuessRows的值会重新被改写回默认值8.

那么有什么办法在SSIS作业前进行检查,事先读取注册表值呢?


1.新建Variable:TypeGuessRows. 方便breakpoint测试。

2.在Script Task当中添加引用命名空间 using Microsoft.Win32;

3.修改主方法如下:

	public void Main()
	{
            Dts.Variables["TypeGuessRows"].Value = (int)Registry.LocalMachine.OpenSubKey(@"SOFTWARE\Wow6432Node\Microsoft\Office\12.0\Access Connectivity Engine\Engines\Excel").GetValue("TypeGuessRows");

            if ((int)Dts.Variables["TypeGuessRows"].Value == 0)
            {
                Dts.TaskResult = (int)ScriptResults.Success;
            }
            else 
            {
                Dts.TaskResult = (int)ScriptResults.Failure;
            }

			
	}

3. 遇sucess则进行后续作业,遇failure则发邮件通知管理员出错




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值