在C ++ 98中使用SQLite时,如何将stringstream
转换为Unicode并将其传递给sqlite3_exec()
?我经常遇到此错误:
error C2440: 'initializing' : cannot convert from 'std::basic_string<_Elem,_Traits,_Ax>' to 'std::basic_string<_Elem,_Traits,_Ax>'
1> with"
代码:
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
const char* data = "Callback function called";
tstringstream tstrsSQL;
tstrsSQL.imbue(std::locale("C"));
std::string s = tstrsSQL.str(); // converting stringstream to char?
const char* p = s.c_str();
/* Open database */
rc = sqlite3_open("db.db3", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
/* Create SQL statement */
tstrsSQL << _T("SELECT") something ("FROM") << table;
/* Execute SQL statement */
rc = sqlite3_exec(db, p, callback, (void*)data, &zErrMsg); // p needs to be unicode
答案 0 :(得分:1)
您使用的是tstringstream
,如果定义了std::wstringstream
,我想使用的是UNICODE
,因此它的str()
给出了std::basic_string<wchar_t>
。
但是您将结果存入std::string
的{{1}}中。因此分配失败。
无论如何,您要获取结果并在std::basic_string<char>
中使用它,而sqlite3_exec()
将作为输入。
这就是为什么您不应该使用const char*
,而应该使用tstringstream
,并从所有字符串文字中删除std::stringstream
的原因。
_T