上一篇谈到读取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则发邮件通知管理员出错