1

以下の関数を使用して、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;
}
4

1 に答える 1

2

列の値はNULLifです。sqlite3_column_type(statement, col) == SQLITE_NULL

于 2013-07-05T17:01:15.670 に答える