关于64bit位系统ODBC找不到的问题
近段时间在把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);