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

int main()
{
    SQLHENV     hEnv;
    SQLHDBC     hDbc;
    //SQLCHAR*  pwszConnStr = (SQLCHAR*)"Driver={MySQL ODBC 5.1 Driver};Server=127.0.0.1;Port=3306;Database=test;Uid=root;Pwd=xxxx;";
    SQLCHAR*    pwszConnStr = (SQLCHAR*)"Driver={SQL Server Native Client 11.0};Server=127.0.0.1,1433;Database=master;Uid=sa;Pwd=xxxx;";


    SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &hEnv);    
    SQLSetEnvAttr(hEnv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0);    
    SQLAllocHandle(SQL_HANDLE_DBC, hEnv, &hDbc);    
    RETCODE rc = SQLDriverConnect(hDbc, NULL, pwszConnStr, SQL_NTS, NULL, 0, NULL, SQL_DRIVER_PROMPT);

    if (rc == SQL_SUCCESS)
    {
        system("pause");
    }
}

我遵循从谷歌搜索的任何代码。但是 RETCODE 一直返回 -1 有什么办法解决这个问题吗?

PS:

  • 我已经安装了所有必要的驱动程序(32/64)
  • 服务器在线
  • 防火墙已关闭
  • 没有freetds,sqlapi++
4

0 回答 0