1

我有_bstr_t字符串,我有wchar_t一个unsigned int我想放入字符串的变量......

_bstr_t strCnn("Driver={SQL Server};Server=some_host,some_port;Database=some_db;User ID=some_user;Password=some_psw;");

wchar_t *host,
unsigned int port,
wchar_t *db_name,
wchar_t *user,
wchar_t *password,

我将这 5 个变量传递给进行连接的函数。你能指导我如何将它们插入连接字符串。

我试过这样:

    wstring ws(host);
    string host_str(ws.begin(), ws.end());
    wstring ws_db(db_name);
    string db_str(ws_db.begin(), ws_db.end());
    wstring ws_user(user);
    string user_str(ws_user.begin(), ws_user.end());
    wstring ws_psw(password);
    string psw_str(ws_psw.begin(), ws_psw.end());

    std::string port_str = std::to_string(port);
    _bstr_t strCnn("Driver={SQL Server};Server="+host_str+","+port_str+";Database="+db_str+";User ID="+user_str+";Password="+psw_str+";");

但它说:

Error E0289 no instance of constructor "_bstr_t::_bstr_t" matches the argument list 
Error C2664 '_bstr_t::_bstr_t(const _bstr_t &) throw()': cannot convert argument 1 from 'std::basic_string<char,std::char_traits<char>,std::allocator<char>>' to 'const char *' 
4

2 回答 2

1

也许最简单的方法是使用std::wstringstream.

您的代码可能类似于:

    std::wstringstream ws;
    ws << "Driver={SQL Server};Server=" << host << "," << port << ";Database=" << db << ";User ID=" << user << ";Password=" << pswr <<";";
    _bstr_t strCnn(ws.str().c_str());

的构造函数_bstr_t需要一个const wchar_t*所以不需要做任何中间转换。

于 2019-05-27T20:16:24.753 回答
1

当您构造要传递给的字符串时strCnn,它是一个std::string对象。 _bstr_t没有接受 a 的构造函数string,但确实有一个接受的构造函数const char *(这是错误消息告诉你的。

简单的解决方法是构造字符串并将其保存在局部变量中,然后将该字符串(转换为 a const char *)传递给_bstr_t构造函数。

std::string port_str = std::to_string(port);
std::string connection = "Driver={SQL Server};Server="+host_str+","+port_str+";Database="+db_str+";User ID="+user_str+";Password="+psw_str+";";
_bstr_t strCnn(connection.c_str());

这可能不是构造字符串的最佳方式(std::stringstream可能更好)。

由于您的原始参数字符串是宽字符,因此您可以使用宽字符(和std::wstring)构造连接字符串。

于 2019-05-27T22:01:40.487 回答