如何使用 sqlite3_step 迭代 sqlite3 中的行
How to iterate the rows in sqlite3 with sqlite3_step?
在SQLite3DB.cpp中,我有一些代码吹奏:
void QueryJsFileBegin() {
SQLite3Initilize();
}
bool QueryJsFileNext(JS_FILE* js_file) {
int err = sqlite3_step(stmtQueryJSFILE);
if (err != SQLITE_ROW)
return false;
// get data.
return true;
}
void QueryJsFileEnd() {
sqlite3_reset(stmtQueryJSFILE);
}
当我在SQLite3DB中测试它们时,这些工作正常.cpp
void test () {
db::JS_FILE js_file;
for (db::QueryJsFileBegin(); db::QueryJsFileNext(&js_file); db::QueryJsFileEnd()) {
MessageBoxA(NULL, js_file.js_file_name_.c_str(), "", 0);
}
}
但是当我在另一个 cpp(如 main.cpp)文件中使用这些文件时,它总是返回第一行和死循环。感谢您的任何帮助。
因为在 for 的step
部分中,您正在运行 sqlite3_reset()
,所以它在第一行之后关闭。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 如何使用 sqlite3_step 迭代 sqlite3 中的行