Qt使用QSqlTableModel界面显示用法(一、默认显示)

这是我的第一篇博客 如果有写的不好的地方请谅解 我会好好学习的!
首先qt使用数据库可以用最基本的exec执行语句,但是本章节我要介绍的是qt中自带的QSqlTableModel来显示数据库的数据。

~~~~~~~~~~
我们在QT中新建一个带有ui的界面项目。
要使用sql头文件或者语句的话,首先要在.pro文件里添加

QT += sql

保存后,QT会自动识别加载sql模块。

.h文件内添加以下内容

#include "qsqldatabase.h"
#include "qmessagebox.h"
#include "qsqlerror.h"
#include "qsqlquery.h"
#include "qsqltablemodel.h"

定义数据连接对象

private:
	QSqlDatabase db;

.cpp内建立连接,一般在构造函数中添加。

	db = QSqlDatabase::addDatabase("QSQLITE");//数据库类型
    db.setDatabaseName("TEST.db");//建立连接,已存在即连接,不存在即建立连接
    if(!db.open())//打开连接
    {
        QMessageBox::warning(this,"wrong",db.lastError().text());
        return;
    }

db.setDatabaseName(“TEST.db”); 生成的db文件在工程目录下位置:
/Users/yucheng/Applications/Learn_Qt/build-learn_QSqlTableodel-Desktop_Qt_6_0_1_clang_64bit-Debug/learn_QSqlTableodel.app/Contents

如果连接失败,查看弹出信息框失败的原因。
为了数据库内有数据可见,我们执行以下函数。

    QSqlQuery query;
    if(!query.exec("create table EXAMPLE("
                   "id integer primary key autoincrement,"
                   "name varchar,"
                   "age integer,"
                   "city varchar"
                   ")"))
        QMessageBox::warning(this,"wrong",query.lastError().text());

    if(!query.exec("insert into EXAMPLE (name,age,city) values ('李四',21,'扬州')"))
        QMessageBox::warning(this,"wrong",query.lastError().text());

插入数据自己定,这里只是提供一个模版。
运行过后如果没有报错则是成功建立一个EXAMPLE表并插入一行数据。接着就是界面设计,我是使用了如下控件:

接下来就是见证奇迹的时刻

在构造函数或自己定义的函数中添加

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

首先,第一句话就是建立一个model模型并连接至db(之前连接的对象)
第二句话就设置model的当前使用表名,因为一个数据库中有多个表名,你对数据库操作肯定要知道是哪个表啊。
第三句话就是当前tableview的应用语句,界面显示的是view,要建立model和tableview之间的关系。
第四句话相当于selec语句,不必阐述。
这里的话就相当于数据库语句

select * from EXAMPLE

这时候,就可以看见运行后的画面了

这个时候大家注意到表头是英文的,且是数据库里的属性名。如果想对界面稍做美化,参考以下代码,都有注释不做过多阐述

    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列升序排序,DescendingOrder降序
    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);//设置列宽,界面看起来更舒适

界面显示

~~~
初始的就这样了。如果有疑问或者不足的地方私信我,感谢!
继续下一章:添加功能的实现

  • 9
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值