插入MySQL命令和C++变量
Intercalate MySQL command with C++ variables
我需要在MySQL命令中插入程序提供的C++变量来创建查询并提交。
我有以下内容:
int source, temperature, humidity, airCo, noise;
char query[500];
尝试#1:
sprintf (query, "insert into defaultsensor1 (dateTime, temperature, humidity, airCo, noise) values (now(), " +
temperature + ", " +
humidity + ", " +
airCo + ", " +
noise + ")";
尝试#2:
sprintf (query, "insert into defaultsensor1 (dateTime, temperature, humidity, airCo, noise) values (now(), %i, %i, %i, %i)",
temperature,
humidity,
airCo,
noise );
尝试#3:
sprintf (query, "insert into defaultsensor1 (dateTime, temperature, humidity, airCo, noise) values (now(), %s, %s, %s, %s)",
std::to_string(temperature),
std::to_string(humidity),
std::to_string(airCo),
std::to_string(noise));
啊啊啊,都没用。
互联网上的教程基本上都围绕着我上面尝试过的内容。我该怎么做?
常规提示,在提供表名时,使用反勾`tablename`
来避免关键字冲突。将字符串字段值置于引号'stringvalue'
中。
对于sql查询,我通常使用std::ostringstream
,因为它会自动将数字转换为字符串。
#include <sstream>
int main()
{
int source, temperature, humidity, airCo, noise;
// ... such and so forth ...
std::ostringstream sql;
sql << "insert into `defaultsensor1`";
sql << " (`dateTime`, `temperature`, `humidity`, `airCo`, `noise`)";
sql << " value ";
sql << "(now(), " << temperature << ", " << humidity << ", " << airCo << ", " << noise << ")";
std::cout << "sql: " << sql.str().c_str() << 'n';
}
注意:使用sql.str().c_str()
从std::ostringstream
中提取字符串,以便传递给MySQL API
调用。
例如。
res = stmt->executeQuery(sql.str().c_str());
这将std::ostringstream
转换为std::string
,然后转换为呼叫所需的const char*
。
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 将数组的地址分配给变量并删除
- 为"adjacent"变量赋值时出现问题
- enum是C++中的宏变量还是整数变量
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- 用C++中的一个变量定义一个常量
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 你能重载对象变量名本身返回的内容吗
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 尝试通过多个向量访问变量时,向量下标超出范围
- 试图让变量检查数组中的某些内容
- Cpp-Tuple使用带有变量的get
- 将包含C样式数组的对象初始化为成员变量(C++)
- 当vector是tje全局变量时,c++中vector的内存管理
- 通过多个头文件使用常量变量
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 执行函数时导致崩溃的变量
- 变量没有改变?通过向量的函数调用