Ошибка SQLite Stop С++, если результаты столбца являются нулевыми

Вопрос:

Я использую функцию ниже для запроса базы данных sqlite. Он работает по большей части, но если столбец возвращает {null}, мое приложение аварийно завершает работу. Как заставить его игнорировать столбцы {null} и вставлять что-то еще вместо них. Я думаю, что мне нужно будет поставить оператор if for (int col = 0; col <cols; col++). Однако я не уверен, как определить, является ли результат {null}

vector<vector<string> > CC_Database::query(string query)
{
sqlite3_stmt *statement;
vector<vector<string> > results;

if(sqlite3_prepare_v2(database, query.c_str(), -1, &statement, 0) == SQLITE_OK)
{
int cols = sqlite3_column_count(statement);
int result = 0;
while(true)
{
result = sqlite3_step(statement);

if(result == SQLITE_ROW)
{
vector<string> values;
for(int col = 0; col < cols; col++)
{
values.push_back((char*)sqlite3_column_text(statement, col));
}
results.push_back(values);
}
else
{
break;
}
}

sqlite3_finalize(statement);
}

string error = sqlite3_errmsg(database);
if(error != "not an error") cout << query << " " << error << endl;

return results;
}

Лучший ответ:

Значение столбца равно NULL если sqlite3_column_type (statement, col) == SQLITE_NULL.

Оцените статью
TechArks.Ru
Добавить комментарий