我想使用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);
}
答案 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更改命令。