我正在尝试确定使用QSqlQuery准备好的语句的正确方法。文档在这个问题上并不十分具体。
void select(const QSqlDatabase &database) {
QSqlQuery query(database);
query.prepare("SELECT * FROM theUniverse WHERE planet = :planet");
query.bindValue(":planet", "earth");
query.exec();
}
这段代码会在连接database
中创建一个永久预备语句吗?这个准备好的陈述是否会在调用select()
之间保持不变,即当函数返回并且QSqlQuery query
被处理时它会被保存吗?
或者我应该在堆上创建QSqlQuery并一遍又一遍地使用相同的实例?
答案 0 :(得分:5)
好的,我的想法是你必须在堆上创建QSqlQuery,准备查询并使用它执行以下操作:
QSqlQuery::bindValue(s)
QSqlQuery::exec
QSqlQuery::[next|first|last|...]
QSqlQuery::finish
以下snipped对于在堆上创建,准备和检索查询非常有用:
QSqlDatabase database;
QMap<QString, QSqlQuery *> queries; //dont forget to delete them later!
QSqlQuery *prepareQuery(const QString &query)
{
QSqlQuery *ret = 0;
if (!queries.contains(query)) {
QSqlQuery *q = new QSqlQuery(database);
q->prepare(query);
queries[query] = ret = q;
} else {
ret = queries[query];
}
}
return ret;
}