我有一个将数据读入地图并将它们写入 sqlite 数据库的应用程序。该应用程序做了很多其他事情,并且是异步的(使用 boost asio),除了写入 db 部分。这是示例伪代码:
struct records;
std::map<int, records> list;
void read() {
// Dump(read) X records into list
// If record id doesn't exist, add it. dirty = true
// If it exists, update all other fields. dirty = true if any fields changed.
}
void writeDB() {
sqlite3_prepare_v2();
for(const auto& record : list) { // iterate map
if(!record.dirty())
continue;
sqlite3_bind(); // bind record fields
sqlite3_step(); // execute sql
sqlite3_reset(); // reset
}
sqlite3_finalize();
}
main() {
while(1) {
read();
writeDB();
}
}
我最初的计划是在 for 循环中生成一个新线程,它将并行写入数据库中的每条记录。有两个问题。
1) 可能需要实现数据库锁定。
2) sqlitebind(), step() and reset()
对同一条语句进行操作。因此,必须按顺序写入记录。
我正在使用 C++ 17。关于使数据库调用异步的任何建议?感谢您的帮助!