QT开发中文网

C++查询数据库后写入Qtableview中配合Qstandaritemmodel

以下是在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查询语句、数据库名称等内容。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:http://qt.0voice.com/?id=897

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?