以下是在C++中查询数据库后将数据写入QTableView中,并使用QStandardItemModel进行配合的示例代码:
#include <QtSql>
#include <QTableView>
#include <QStandardItemModel>
int main(int argc, char *argv[])
{
QApplication app(argc, argv);
// 创建一个QTableView并设置其父对象
QTableView *tableView = new QTableView();
tableView->setParent(0);
// 创建一个QStandardItemModel
QStandardItemModel *model = new QStandardItemModel();
// 连接到数据库
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("test.db");
// 打开数据库连接
if (!db.open()) {
qWarning() << "Failed to open database";
return -1;
}
// 执行SQL查询
QSqlQuery query("SELECT * FROM mytable");
// 为QStandardItemModel设置列数和行数
model->setColumnCount(query.record().count());
model->setRowCount(query.size());
// 将查询结果添加到QStandardItemModel中
int row = 0;
while (query.next()) {
for (int column = 0; column < query.record().count(); ++column) {
QString value = query.value(column).toString();
QStandardItem *item = new QStandardItem(value);
model->setItem(row, column, item);
}
++row;
}
// 将QStandardItemModel设置为QTableView的模型
tableView->setModel(model);
// 显示QTableView
tableView->show();
return app.exec();
}
注意,在实际应用中,需要根据具体的需求对上述代码进行修改。例如,需要根据实际情况修改SQL查询语句、数据库名称等内容。