7
 ...
 query.exec("insert into person values(104, 'Roberto', 'Robitaille')");
 query.exec("insert into person values(105, 'Maria', 'Papadopoulos')");
 ...

这些可以绑定在单个query.exec()中吗?

4

1 回答 1

14

我猜你正试图批量执行你的查询。是的,qt 支持这种情况。

bool QSqlQuery::execBatch ( BatchExecutionMode mode = ValuesAsRows )

批量执行之前准备好的 SQL 查询。所有绑定参数都必须是变体列表。如果数据库不支持批处理执行,驱动程序将使用常规的 exec() 调用来模拟它。如果查询执行成功,则返回 true;否则返回假。

 QSqlQuery q;
 q.prepare("insert into myTable values (?, ?)");

 QVariantList ints;
 ints << 1 << 2 << 3 << 4;
 q.addBindValue(ints);

 QVariantList names;
 names << "Harald" << "Boris" << "Trond" << QVariant(QVariant::String);
 q.addBindValue(names);

 if (!q.execBatch())
     qDebug() << q.lastError();

http://doc.qt.io/archives/qt-4.7/qsqlquery.html#execBatch

于 2012-03-17T09:00:36.143 回答