QtSql多次查询执行

时间:2012-03-17 06:31:43

标签: qt qt4 qtsql

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

这些可以绑定在一个 query.exec()

1 个答案:

答案 0 :(得分:12)

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

bool QSqlQuery::execBatch ( BatchExecutionMode mode = ValuesAsRows )
  

批量执行以前准备的SQL查询。所有的约束   参数必须是变体列表。如果数据库没有   支持批处理执行,驱动程序将使用它来模拟它   传统的exec()调用。如果执行查询,则返回true   成功;否则返回false。

 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