消息:[unixODBC] [驱动程序管理器]无法打开lib'MySQL ODBC 5.1驱动程序':找不到文件nSQLSTATE:01000

时间:2014-06-04 10:31:36

标签: c++ mysql linux odbc

我想使用c ++和mysql创建一个odbc连接,并附上了我的代码。 请帮我纠正错误,这是我发布的问题的标题。

#include <iostream>
#include <sql.h>
#include <sqlext.h>
#include <sqltypes.h>

using namespace std;

void show_error(unsigned int handletype, const SQLHANDLE& handle) {
    SQLCHAR sqlstate[1024];
    SQLCHAR message[1024];
    if(SQL_SUCCESS == SQLGetDiagRec(handletype, handle,
           1, sqlstate, NULL, message, 1024, NULL))
        cout<<"Message: "<<message<<"SQLSTATE: "<<sqlstate<<endl;
}

int main() {
    SQLHANDLE sqlenvhandle;    
    SQLHANDLE sqlconnectionhandle;
    SQLHANDLE sqlstatementhandle;
    SQLRETURN retcode;

    if(SQL_SUCCESS!=SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &sqlenvhandle))
        goto FINISHED;

    if(SQL_SUCCESS!=SQLSetEnvAttr(sqlenvhandle,
           SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0)) 
        goto FINISHED;

    if(SQL_SUCCESS!=SQLAllocHandle(SQL_HANDLE_DBC, sqlenvhandle, &sqlconnectionhandle))
        goto FINISHED;

    SQLCHAR retconstring[1024];
    switch(SQLDriverConnect (sqlconnectionhandle, NULL, 
                (SQLCHAR*)"DRIVER={MySQL ODBC 5.1 Driver};PORT=3306;SERVER=localhost;DATABASE=market;UID=root;PWD=123;", 
                SQL_NTS, 
                retconstring, 
                1024, 
                NULL,
                SQL_DRIVER_NOPROMPT)){
     case SQL_SUCCESS_WITH_INFO:
          show_error(SQL_HANDLE_DBC, sqlconnectionhandle);
          break;
     case SQL_INVALID_HANDLE:
     case SQL_ERROR:
          show_error(SQL_HANDLE_DBC, sqlconnectionhandle);
          goto FINISHED;
     default:
          break;
    }

    if(SQL_SUCCESS!=SQLAllocHandle(SQL_HANDLE_STMT, 
           sqlconnectionhandle, &sqlstatementhandle))
        goto FINISHED;

    if(SQL_SUCCESS!=SQLExecDirect(sqlstatementhandle
           SQLCHAR*)"select * from employee", SQL_NTS)) {
        show_error(SQL_HANDLE_STMT, sqlstatementhandle);
        goto FINISHED;
    }
    else{
        char name[64];
        char dept[64];

        while(SQLFetch(sqlstatementhandle)==SQL_SUCCESS){
            SQLGetData(sqlstatementhandle, 1, SQL_C_CHAR, name, 64, NULL);
            SQLGetData(sqlstatementhandle, 2, SQL_C_CHAR, dept, 64, NULL);
            cout<<" "<<name<<" "<<dept<<endl;
        }
    }

    FINISHED:
    SQLFreeHandle(SQL_HANDLE_STMT, sqlstatementhandle );
    SQLDisconnect(sqlconnectionhandle);
    SQLFreeHandle(SQL_HANDLE_DBC, sqlconnectionhandle);
    SQLFreeHandle(SQL_HANDLE_ENV, sqlenvhandle);

}

2 个答案:

答案 0 :(得分:0)

您对SQLDriverConnect的调用中的Driver属性是“MySQL ODBC 5.1 Driver”,因此您应该在odbcinst.ini文件中有一个条目,如下所示:

[MySQL ODBC 5.1 Driver]
driver = /some/path/to/libxxx.so

您需要检查/some/path/to/libxxx.so是否存在,是否可读,可执行,最后可能在其上运行ldd以确保已经安装了它所依赖的任何内容。

您可以使用命令odbcinst -j找到odbcinst.ini文件。

答案 1 :(得分:0)

您需要确保执行下面列出的所有步骤。

1)在驱动程序的so文件上运行ldd以检查是否已加载所有必需的库。如果您发现无法找到某些库,请在LD_LIBRARY_PATH环境变量中手动添加这些库的路径。

2)创建odbcinst.ini文件(如果该文件尚不存在)并添加到下面的条目

[MySQL ODBC 5.1 Driver]
Description     = ODBC for MySQL
Driver          = <Path_to_Dir_where_you_have_installed_driver>/libxxx.so
Setup           = <Path_to_Dir_where_you_have_installed_driver>/libxxx.so

3)将环境变量ODBCINST设置为指向刚刚创建的odbcinst.ini。    例如如果您使用的是bash shell,则可以设置如下所示的变量

export ODBCINST=<path_to_dir_where_odbcinst.ini_is_craeted>/odbcinst.ini

您可以根据您使用的shell相应地更改命令。

4)仅在某些情况下设置ODBCINST是不够的,您需要设置ODBCSYSINI以确保它正在拾取您在上一步中将ODBCINST设置为的odbcinst.ini文件。

export ODBCSYSINI=<path_to_dir_where_odbcinst.ini_is_created>

再次根据您正在使用的shell更改命令。