...
query.exec("insert into person values(104, 'Roberto', 'Robitaille')");
query.exec("insert into person values(105, 'Maria', 'Papadopoulos')");
...
这些可以绑定在单个query.exec()中吗?
我猜你正试图批量执行你的查询。是的,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();