关于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);
posted on 2011-01-08 15:00  Melou  阅读(2018)  评论(0编辑  收藏  举报