Не удается подключиться к базе данных доступа с использованием c ++, odbc

Rc возвращает -1, но я не могу получить сообщение об ошибке и статус после вызова SQLGetDiagRec

SQLRETURN rc;
SQLHENV henv1 = NULL;
SQLHDBC hdbc1= NULL;
SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv1);
SQLSetEnvAttr(henv1,SQL_ATTR_ODBC_VERSION,(void*)SQL_OV_ODBC3,0);
rc =SQLAllocHandle(SQL_HANDLE_DBC, henv1, &hdbc1);

char szDSN[256] = "Driver={Microsoft Access Driver (*.mdb, *.accdb)};DSN=data;DBQ=D:\\data\\data.accdb;";
char out[256];
int     iConnStrLength2Ptr;
rc = SQLDriverConnect(hdbc1, NULL, (SQLWCHAR*)&szDSN, SQL_NTS, (SQLWCHAR*)&out,255, (SQLSMALLINT*)&iConnStrLength2Ptr, SQL_DRIVER_NOPROMPT);

SQLWCHAR SQLState[256];
SQLINTEGER NativeErrorPtr;
SQLWCHAR MessageText[256];
SQLSMALLINT TextLengthPtr = 255;
SQLGetDiagRec(SQL_HANDLE_ENV,henv1,1,(SQLWCHAR*)SQLState,&NativeErrorPtr,(SQLWCHAR*)MessageText,255,&TextLengthPtr);

0

Решение

Вы на самом деле не показывает часть кода, посвященную тестированию ошибок. После SQLDriverConnect вы должны проверить! SQL_SUCCEEDED (rc). Вызов SQLGetDiagRec находится на дескрипторе среды, но ошибка произошла на дескрипторе соединения, поэтому вы, вероятно, хотите изменить свой вызов на SQLGetDiagRec.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]