关于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:

 

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

 

通过程序创建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);

你可能感兴趣的:(odbc)