Хобрук: Ваш путь к мастерству в программировании

Как найти строку в таблице sql

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

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

  • Что ты имеешь в виду под словом умереть? 12.02.2013
  • @КЛ. под die я имею в виду, что процесс (embedded-linux) просто уходит, не знаю, кто его убивает и почему. Но код работает без проблем, когда ifFound заглушен, что делает вполне уверенным, что проблема связана с sqlite3_get_table. 12.02.2013
  • В этой функции нет ничего явно плохого. Разве вы не можете запустить свою программу с помощью отладчика или на рабочем столе? 12.02.2013
  • Да. Я знаю - функция на самом деле работает, просто не очень долго. 13.02.2013
  • Поэтому я добавил обратный вызов и глобальную переменную для хранения количества совпадений. Я отправлю код в ответ. После того, как он работает хорошо некоторое время. 13.02.2013

Ответы:


1

Один из способов избавиться от 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);
}
12.02.2013
Новые материалы

Структуры данных в C ++ - Часть 1
Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

Как я опубликовал свое первое приложение в App Store в 13 лет
Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..

Что в лицо
Очерк о возвращении физиогномики и о том, почему мы должны это приветствовать. История начинается со странной науки. Р. Тора Бьорнсдоттир, Николас О. Рул. Видимость социального класса по..

Почему шаблоны проектирования и почему нет?
Сложность — мать всех проблем в программировании. Программное обеспечение должно быть разработано с точки зрения того, кто его поддерживает, а не того, кто его пишет, потому что программное..

Создание дизайна обуви с помощью машинного обучения
Обувь. Что подождать? Я думал, что речь пойдет о машинном обучении! Ну это так. Если бы вы пошли на Amazon, сколько обуви вы бы нашли? Наверное, много, не так ли? Но много ли в них..

GraalVM в 2022 году: итоги года
2022 год был очень продуктивным для проекта и сообщества GraalVM. Вместе мы разработали множество новых функций, выпустили GraalVM для последних версий Java и новых платформ и увидели несколько..

Быстрая разработка: волшебный мир больших языковых моделей
РУКОВОДСТВО Быстрая разработка: волшебный мир больших языковых моделей Подход, основанный на данных, для получения наилучшего ответа Искусство и наука Можно ли совместить машинное..