2011-09-23 79 views
2

爲了提高性能,我在代碼中使用了相當多的參數化查詢。總之,其中一些工作,一些不工作。在參數化查詢中參數計數不匹配

我建設我的數據庫包裝的過程中初始化這樣的查詢:

QString querystring = QString("SELECT somevalue FROM sometable " 
         "WHERE one_feature = :one_feature AND other_feature = :other_feature "); 
myquery = QSqlQuery(db); 
myquery.setForwardOnly(true); 
myquery.prepare(querystring); 

myquery是我的數據庫包裝的QSqlQuery成員變量。後來,在想要使用此查詢的功能,我這樣做

int db_wrapper::fetch_some_value (int arg1, int arg2) { 
    myquery.clear(); 
    myquery.bindValue(":one_feature", arg1); 
    myquery.bindValue(":other_feature", arg2); 

    qDebug() << "Bound values: " << myquery.boundValues(); 

    bool OK = myquery.exec(); 
    if (!OK) { 
     int number = myquery.lastError().number(); 
     qDebug() << "db error " << number; 
     qDebug() << "db error " << myquery.lastError().text(); 

#ifdef USE_EXCEPTIONS 
     throw "Could not fetch some_value!"; 
#endif 
    } 

    // process data... 
} 

我總是得到同樣的錯誤信息/輸出:

Bound values: QMap((":one_feature", QVariant(int, 1)) (":other_feature" , QVariant(int, 1))) 
db error -1 
db error " Parameter count mismatch" 
terminate called after throwing an instance of 'char const*' 

唯一的例外是不奇怪的,但參數計數不匹配是。對boundValues的調用實際上顯示了正確的值和全部,但我仍然收到此錯誤消息。我有類似的查詢,工作得很好。

我試着替換位置綁定值,重命名佔位符,使用?和位置綁定值,都無濟於事。有沒有人有一個想法可能是什麼問題?

我使用Qt 4.7.3和SQLite 3.7.4-2

+0

表中的字段是否聲明爲int?你可以嘗試使用文本(並通過引用字符串)? – Louis

+0

是的,這些字段在生成SQL腳本中聲明爲「one_feature」整數NOT NULL REFERENCES「feature_table」(「id」)'。不幸的是,改變表格不是一種選擇。我也嘗試引用'querystring'中的參數,但那也不起作用。 – arne

+0

麪包屑爲他人:我有這個錯誤,但我的問題是,我沒有引用反向列名',我有一個列名也是一個sqlite關鍵字。 –

回答

5

通常這個錯誤意味着SELECT/UPDATE查詢本身就是不正確。您沒有給出數據庫的模式,因此無法確定哪一個模式。因此,somevalue,sometable,one_featuresecond_feature中的一個或多個不在數據庫/表中。

+0

我無法發佈架構,對不起。但是,我嘗試在SQLite數據庫瀏覽器中用參數1和1替代(如示例中所示)來執行查詢。這工作正常。 – arne

+0

如何查詢query.clear()調用?它是否像你在例子中指定的?如果在prepare()之後調用它,它將從查詢中刪除它。調用clear()通常不是必需的。 –

+0

我嘗試過,沒有清楚,這沒有什麼區別。 – arne