Как найти str в таблице sql

Код просто должен сообщить вызывающей стороне, если path в таблице или нет.
Код C ++ ниже делает это правильно, используя select count(*) а также sqlite3_get_table но ненадолго потом умирает.
Очевидно, есть проблемы с sqlite3_get_table.
Есть очень похожий вопрос Вот но я не вижу, как применить этот ответ к моей проблеме.
Я прочитал документы по sqlite и прошел учебник по sqlite.
Я использовал sqlite3_exec для инициализации базы данных и вставки новых записей, но опять же не вижу, как написать надежный метод c ++, который просто возвращает bool, если он находит или не находит совпадения в таблице. Как я уже сказал, приведенный ниже код работает, но не для нескольких сотен звонков. Разве это не должно быть одним из самых простых дел с базой данных? Есть ли простые примеры того, как это сделать, или предложения, как лучше всего решить эту проблему?

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);
}

0

Решение

Один из способов избавиться от sqlite3_get_table — заменить его на sqlite3_exec, обратный вызов для обработки результата запроса и глобальную переменную для хранения счетчика.

static int pathFound = 0;
int sqlCallback(void *p, int argc, char **argv, char **azColName) {
pathFound = atoi(argv[0]);
return 0;
}
void checkPath(string path) {
string sqlCommand = "select count(*) from m_table where path='"+path+"'";
rc = sqlite3_exec(db, sqlCommand.c_str(), sqlCallback, 0, &zErrMsg);
if (SQLITE_OK != rc) {
coutError(__FILE__, __LINE__, sqlCommand + "\n" + zErrMsg);
sqlite3_free(zErrMsg);
}
sqlite3_close(db);
if (0 == pathFound) doInsert(path);
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector