2013-07-05 45 views
0

我正在使用下面的函數來查詢sqlite數據庫。它大部分工作,但如果列返回{null}我的應用程序崩潰。 如何強制它忽略{null}列並在其位置插入其他內容。 我想我需要把一個if語句中的for(int列= 0;西<的cols;山坳++) 但是我不確定如何確定結果爲{空}如果列結果爲空,C++ SQLite停止錯誤

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

回答