如何将字符串插入sql查询?

时间:2014-06-16 21:14:54

标签: c++ mysql sql c

下面的

是我的代码的一部分,

 ...
 char hashvalue[]="somehash"; // or i can use std::string

 SQLCHAR* query = (SQLCHAR*)"SELECT username FROM users WHERE hash = ..." ;
 SQLExecDirectA( hStmt, query, SQL_NTS );
 ...

在上面的代码中,我不知道如何插入查询hashvalue来执行我的查询,如下所示:

 SQLCHAR* query = (SQLCHAR*)"SELECT username FROM users WHERE hash = "somehash"" ;

我对sql很新,感谢您提前寻求帮助。

1 个答案:

答案 0 :(得分:2)

使用std::string

std::string query_string = "SELECT username FROM users WHERE hash = ";
query_string += hashvalue;
SQLExecDirectA(hStmt, query_string.c_str(), SQL_NTS);

另一种方法:

char query_buffer[1024];
snprintf(query_buffer,
         "SELECT username FROM users WHERE hash = %s",
         hashValue);
SQLExecDirectA(hStmt, query_buffer, SQL_NTS);

基本上,您的问题是如何创建格式化字符串并与SQL无关。