2012-07-19 84 views
1

当我在32位delphi应用程序中运行此代码时,与MySql的连接已成功建立。TADOConnection在delphi xe2中不工作64位

{$APPTYPE CONSOLE} 

{$R *.res} 

uses 
    AdoDb, 
    ActiveX, 
    SysUtils; 

Var 
    LConn : TADOConnection; 
begin 
    try 
    CoInitialize(nil); 
    try 
     LConn:=TADOConnection.Create(nil); 
     try 
     LConn.ConnectionString:='Driver={MySQL ODBC 5.1 Driver};Server=127.0.0.1;Database=mysql;User=*****; Password=*****;Option=3'; 
     LConn.Connected:=True; 
     Writeln('Connected'); 
     finally 
     LConn.Free; 
     end; 
    finally 
     CoUninitialize; 
    end; 
    except 
    on E: Exception do 
     Writeln(E.ClassName, ': ', E.Message); 
    end; 
    Readln; 
end. 

但相同的代码代码失败与此异常

EOleException:[微软] [ODBC驱动程序管理器]数据源名称未 发现并没有指定默认驱动程序

如果该代码被编译为64位应用程序。问题是为什么相同的代码在64位应用程序中失败?

回答

5

为避免此异常,您必须安装MySQL ODBC driver for 64 bits

+2

+1。我在评论中说过(我马上会删除它),但没有链接,所以我没有发布答案。 :-) – 2012-07-19 03:13:52