您的位置:首页 > 其它

关于64bit位系统ODBC找不到的问题

2011-01-08 15:00 169 查看
近段时间在把32位系统下编译的程序移植到Windows Server 2003 64bit 系统上时,突然发现找不到ODBC驱动,经过一番研究发现是由于64bit系统中32位的ODBC是在系统的syswow64 目录下面,且写入注册表是的节点为Wow6432Node 当运行32位的程序时是不可能找到32的ODBC驱动的,如果开发程序, 建议编译成为X86形式的, 这样就可以在64位系统正常使用ODBC,如果要通过程序创建ODBC数据源,还要将写入注册表的节点改为Wow6432Node,这样就可以在64bit 位系统中正常使用ODBC数据源了。

在VS工具中设置编译为X86:





通过程序创建ODBC数据源:

RegistryKey regKey = Registry.LocalMachine.OpenSubKey("SOFTWARE").OpenSubKey("Wow6432Node").OpenSubKey("ODBC").OpenSubKey("ODBC.INI", true).CreateSubKey(dsn);

string driverPath = GetDriverDllPath();
if (string.IsNullOrEmpty(driverPath))
{
return false;
}
string tcpIP = string.Format("host={0};port={1}", serverIP, port);
regKey.SetValue("AutoStop", "YES");
regKey.SetValue("Driver", driverPath);
regKey.SetValue("CommLinks", "TCPIP{" + tcpIP + "}");
regKey.SetValue("Debug", "No");
regKey.SetValue("Compress", "No");
regKey.SetValue("DisableMultiRowFetch", "No");
regKey.SetValue("Description", description);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐