QT5 SQL数据库使用model在tableview中显示

1.新建一个QT Widgets Application

2. 在pro中间中添加sql 

        QT += sql

3.mainwindows.h中添加头文件

#include <QSqlDatabase>
#include <QMessageBox>
#include <QSqlError>
#include <QSqlTableModel>
#include <QSqlQuery>
#include <QDebug>

4.ui中添加一个tableview

5.MainWindow构造函数中添加简单代码:

    qDebug() << QSqlDatabase::drivers() ;

    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");//数据库类型
    db.setDatabaseName("test");//建立连接,已存在即连接,不存在即建立连接
    db.setUserName("root");
    db.setPassword("123456");
    if(!db.open())//打开连接
    {
        QMessageBox::warning(this,"wrong",db.lastError().text());
        return;
    }
    else{
        QMessageBox::information(this, "infor", "link success");
    }




    QSqlTableModel * model = new QSqlTableModel(this,db);
    model->setTable("student");
    ui->tableView->setModel(model);
    model->select();

    QStringList tables;
    tables << "id" << "姓名" << "年龄" << "城市";
    for(int i = 0 ; i < tables.count(); i++)
        model->setHeaderData(i,Qt::Horizontal,tables[i]);//设置显示框表头显示
    model->setSort(0,Qt::AscendingOrder);//设置按照第0列排序
    ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);//设置单元格不可编辑
    ui->tableView->horizontalHeader()->setStretchLastSection(true);//设置最后一列填充后面表格
    ui->tableView->setColumnHidden(0,true);//设置第0行隐藏
    ui->tableView->setColumnWidth(1,50);//设置列宽,界面看起来更舒适
    ui->tableView->setColumnWidth(2,30);//设置列宽,界面看起来更舒适

6.确保或新建一个mysql的数据库,名字为test,包含一个名字为student的表,表中添加几列数据,注意数据库名和表名要跟第5步中代码的名字一致!

 7.直接运行看效果

8.把代码中设置单元格不可编译这一条注释掉以后,还可以直接修改内容,软件会自动同步到数据库中!!!很强悍

9.又更新了完整功能

每页只显示10行,每页中的每列可以排序,能删除选定行,增加一行,跳转到第一页、上一页、下一页、最后页,点击单元格可以修改内容并同步保存到数据库等。。。

效果如下:

源码如下:

https://download.csdn.net/download/Running_A/87904695

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用QtTableView显示数据库数据时,需要使用Model-View架构来实现。具体步骤如下: 1.创建数据库连接 需要使用Qt自带的QSqlDatabase类来创建数据库连接,并且需要指定数据库类型、主机地址、数据库名、用户名和密码等信息。 2.创建数据模型 使用Qt自带的QSqlTableModel类来创建数据模型,并且需要指定数据表名和数据库连接等信息。 3.设置TableView 使用Qt自带的QTableView类来显示数据,并且需要设置数据模型、列宽、列标题等信息。 4.使用委托 使用Qt自带的QItemDelegate类来创建委托,并且需要重写委托的paint()和createEditor()等函数来实现自定义的数据显示和编辑功能。 5.保存数据 在数据发生变化时,需要使用数据模型的submitAll()函数来保存数据到数据库。 完整代码如下: ``` #include <QtWidgets> #include <QtSql> class MyDelegate : public QItemDelegate { public: MyDelegate(QObject *parent = nullptr): QItemDelegate(parent) {} void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const override { // 自定义绘制函数,显示数据时添加单位 QString text = index.data().toString() + " kg"; drawDisplay(painter, option, option.rect, text); } QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override { // 自定义编辑函数,编辑时去掉单位 QLineEdit *editor = new QLineEdit(parent); QString text = index.data().toString(); editor->setText(text.left(text.indexOf(" "))); return editor; } void setEditorData(QWidget *editor, const QModelIndex &index) const override { QString text = index.data().toString(); QLineEdit *lineEdit = static_cast<QLineEdit*>(editor); lineEdit->setText(text.left(text.indexOf(" "))); } void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const override { QLineEdit *lineEdit = static_cast<QLineEdit*>(editor); QString text = lineEdit->text() + " kg"; model->setData(index, text, Qt::EditRole); } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建数据库连接 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("test.db"); if (!db.open()) { qDebug() << "Failed to connect to database!"; return -1; } // 创建数据模型 QSqlTableModel model; model.setTable("weight"); model.select(); // 设置TableView QTableView tableView; tableView.setModel(&model); tableView.setItemDelegate(new MyDelegate); tableView.setColumnWidth(0, 150); tableView.setColumnWidth(1, 100); tableView.setHorizontalHeaderLabels(QStringList() << "Name" << "Weight"); // 保存数据 QPushButton saveButton("Save"); QObject::connect(&saveButton, &QPushButton::clicked, [&model]() { model.submitAll(); }); // 显示窗口 QVBoxLayout layout; layout.addWidget(&tableView); layout.addWidget(&saveButton); QWidget window; window.setLayout(&layout); window.show(); return app.exec(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值