如果列结果为空,则 C++ SQLite 停止错误

标签 c++ vector sqlite

我正在使用下面的函数来查询 sqlite 数据库。它在大多数情况下都有效,但如果一列返回 {null},我的应用程序就会崩溃。 我如何强制它忽略 {null} 列并在其位置插入其他内容。 我在想我需要在 for(int col = 0; col < cols; col++) 中加入一个 if 语句 但是我不确定如何确定结果是否为 {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;
}

最佳答案

如果 sqlite3_column_type,则列值为 NULL (statement, col) == SQLITE_NULL

关于如果列结果为空,则 C++ SQLite 停止错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17492847/

相关文章:

c++ - 试图理解模板

c++ - 使用 const 数组的元素在类中定义数组大小时,“数组边界不是整数常量”

c++ - 如何调整 2D C++ vector 的大小?

python - 重击 : sqlite3: command not found

android - Room 数据库迁移测试中出现 "no such table: alarmInfo"的原因是什么?

c++ - DOM 解析器中的 SetContent 错误

c++ - 为什么我的构造函数允许使用临时对象调用非 const 引用作为参数?

C++:取消引用 vector<vector<class_ptr*>>

c++ - 从 std::vector 中的每个对象调用重载函数

android - SQLite:使用 LIKE '%?%' 和 rawQuery 选择