QSqlQuery query; QString baseValue = "0"; for(int i = 0; i < 25; i++) { QString value = baseValue + QString::number(i+1); // 不同的字段值 query.prepare("INSERT INTO classinfo(number,capacity,time) VALUES (:value1, :value2, :value3)"); query.bindValue(":value1", ui->numlineEdit->text()); // 绑定参数:value的值为不同的字段值 query.bindValue(":value2", ui->vectorlineEdit->text()); query.bindValue(":value3", value); if (!query.exec()) { QMessageBox::warning(this,"添加提示","添加失败"); return; } } if (query.exec()) { QMessageBox::information(this,"添加提示","添加成功"); } else { QMessageBox::warning(this,"添加提示","添加失败"); } }这段代码最后为什么会创建两个time字段值相同的数据?
时间: 2024-02-14 18:28:02 浏览: 64
在你提供的代码中,创建两个time字段值相同的数据的问题是因为在插入数据之前你执行了两次`query.exec()`。当你在循环内部执行`query.exec()`时,它会立即执行SQL语句并返回执行结果。然而,在循环结束后,你又执行了一次`query.exec()`。
因此,你可以将第二次执行`query.exec()`的代码删除。以下是修改后的代码:
```cpp
QSqlQuery query;
QString baseValue = "0";
for(int i = 0; i < 25; i++)
{
QString value = baseValue + QString::number(i+1); // 不同的字段值
query.prepare("INSERT INTO classinfo(number, capacity, time) VALUES (:value1, :value2, :value3)");
query.bindValue(":value1", ui->numlineEdit->text()); // 绑定参数:value的值为不同的字段值
query.bindValue(":value2", ui->vectorlineEdit->text());
query.bindValue(":value3", value);
if (!query.exec()) {
QMessageBox::warning(this,"添加提示","添加失败");
return;
}
}
QMessageBox::information(this,"添加提示","添加成功");
```
这样,循环内部只执行一次插入操作,并在循环结束后显示成功的提示框。这样就可以避免创建两个time字段值相同的数据的问题。
阅读全文