代码只需要让调用者知道是否path
在表中。下面的 c++ 代码正确使用但仅在短时间内完成了此操作,然后就死了select count(*)
。sqlite3_get_table
sqlite3_get_table 显然存在问题。这里有一个非常相似的问题但我不知道如何将此答案应用于我的问题。我已经阅读了 sqlite 文档并完成了 sqlite 教程。我已经使用 sqlite3_exec 来初始化数据库并插入新记录,但同样,看不到如何编写一个健壮的 c++ 方法,如果它在表中找到或未找到匹配项,它只返回一个布尔值。正如我所说,下面的代码有效,但不能用于数百次调用。这不应该是与数据库有关的最简单的事情之一吗?是否有任何简单的示例说明如何执行此操作或有关解决此问题的最佳方法的建议?
bool ifFound(string path) {
if (turn_off) return false;
char **result;
int nrow = 0; // Number of result rows
int ncol = 0; // Number of result columns
char * zErrMsg = 0; // Error message
if (SQLITE_OK != sqlite3_open(database_path.c_str(), &db)) {
coutError(__FILE__, __LINE__, "Can't open database " + database_path);
return false;
}
int count = 0;
string sqlCommand = "select count(*) from my_table where path='"+path+"'";
if (SQLITE_OK ==
sqlite3_get_table(db, sqlCommand.c_str(),&result,&nrow,&ncol,&zErrMsg))
count = atoi(result[ncol]);
else coutError(__FILE__, __LINE__, sqlCommand + " " + zErrMsg);
sqlite3_free_table(result);
sqlite3_close(db);
return (count != 0);
}