在sql中使用c++代码中的变量
Using variable from c++ code in sql
我现在正在使用sqlite3。我想在SELECT中使用变量barcode_prog。我有数据库sql_db与表PT和列条形码和名称的文件。但我想在SELECT中使用任何人的字符串,这将在程序中设置。我在代码的注释中问我的问题。请帮忙:)
#include "stdafx.h"
#include "sqlite3.h"
#include <iostream>
int data (void *unused, int field_num, char **value, char **field_name)
{
for (int i = 0; i < field_num; i++)
{
std::cout << value[i] << " = " << field_name[i] << std::endl;
}
return 0;
}
int main()
{
int error;
char *barcode_prog = "4813538002837";
char *errmsg;
sqlite3 *db;
char *sql = "SELECT * FROM PT WHERE ?"; // here i want to use barcode_prog like "SELECT * FROM PT WHERE BarCode = barcode_prog"
error = sqlite3_open("sql_db", &db);
if (error != SQLITE_OK)
{
std::cout << "Cannot read database" << sqlite3_errmsg(db) << std::endl;
}
error = sqlite3_exec(db, sql, data, 0, &errmsg);
if (error != SQLITE_OK)
{
std::cout << "ERROR!" << errmsg << std::endl;
sqlite3_free(errmsg);
}
system ("pause");
sqlite3_close(db);
return 0;
}
可能有几种方法可以做到这一点。我认为最简单的方法是使用std::stringstream。
// your code
std::stringstream stream;
stream << "SELECT * FROM PT WHERE BarCode = " << barcode_prog.
// ...
error = sqlite3_exec(db, stream.str().c_str(), data, 0, &errmsg);
//...
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 代码在main()中运行,但在函数中出现错误
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 编译包含字符串的代码时遇到问题
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 在Linux for Windows上编译C++代码时出错
- 我的字符计数代码计算错误.为什么
- 孤立代码块在结构中引发异常
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 此代码是否违反一个定义规则
- 为什么我的代码在输出中增加了93天
- 我的简单if-else语句是如何无法访问的代码
- 使用动态分配的数组会导致代码分析发出虚假的C6386缓冲区溢出警告
- 为什么在这个代码结束循环中没有得到结束
- 在c代码之间共享数据的最佳方式
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值