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

Posted

技术标签:

【中文标题】如果列结果为空,C++ SQLite 停止错误【英文标题】:C++ SQLite Stop Error If Column Results Are Null 【发布时间】:2013-07-05 15:57:54 【问题描述】:

我正在使用下面的函数来查询一个 sqlite 数据库。它在大多数情况下都有效,但如果一列返回 null 我的应用程序崩溃。 如何强制它忽略 null 列并在其位置插入其他内容。 我想我需要在 for(int col = 0; col

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;

【问题讨论】:

【参考方案1】:

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

【讨论】:

以上是关于如果列结果为空,C++ SQLite 停止错误的主要内容,如果未能解决你的问题,请参考以下文章

sqlite条件查询查询blob

如何检查edittext是不是为空?

如果 SQLite 为空或有记录,则更改片段中的视图

SQLite 选择哪里为空?

如果请求值为空,Laravel 设置默认值

如何用SQL语句来判断查询结果为空?