在QT中使用QTableView与数据库连接

2024-04-21 15:44

本文主要是介绍在QT中使用QTableView与数据库连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、界面与数据库连接,使用QSqlTableModel对数据处理

//界面初始化
void TestProSetWid::initsqlmodel()
{// 连接SQLite数据库db = QSqlDatabase::addDatabase("QSQLITE","second");db.setDatabaseName("./testitem.db"); // 替换为你的数据库文件路径if (!db.open()) {qDebug() << "Failed to connect to database";return;}elseqDebug()<<"连接数据库成功"<<endl;// 创建数据模型   /* QSqlQueryModel 适合用于查询数据,不能修改数据 */dbmodel = new QSqlTableModel(this, db);dbmodel->setTable("order_settings"); // 替换为你的表名   第一页订单号/* 如果有修改则同步修改到数据库,* 注意这个规则需要与 tabview 这样的控件才生效,* 因为 tabview 可以直接编辑表里的内容 */dbmodel->setEditStrategy(QSqlTableModel::OnFieldChange);dbmodel->select();//    if(!dbmodel->select())//        qDebug()<<"err"<<endl;mProxyModel = new QRowsLimitProxyModel;mProxyModel->setSourceModel(dbmodel);  //排序 筛选功能mProxyModel->setDynamicSortFilter(true);/* 设置表格的头信息,若不设置则显示数据库里的英文字段头信息 */dbmodel->setHeaderData(dbmodel->fieldIndex("order_num"),Qt::Horizontal, tr("订单"));dbmodel->setHeaderData(dbmodel->fieldIndex("tested_product_type"),Qt::Horizontal, tr("类型"));dbmodel->setHeaderData(dbmodel->fieldIndex("inspect_unit"),Qt::Horizontal, tr("单位"));dbmodel->setHeaderData(dbmodel->fieldIndex("test_number"),Qt::Horizontal, tr("编号"));// 将查询结果绑定到TableView上ui->tableView->setModel(mProxyModel);// 设置内容居中显示CenterAlignedDelegate *delegate = new CenterAlignedDelegate(this);ui->tableView->setItemDelegate(delegate);ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);// 设置第一列的Stretch,将第一列的列宽设置为100像素ui->tableView->horizontalHeader()->setSectionResizeMode(0, QHeaderView::Fixed);ui->tableView->setColumnWidth(0, 100);//    ui->tableView->verticalHeader()->setSectionResizeMode(0, QHeaderView::Fixed);// 设置行高ui->tableView->verticalHeader()->setDefaultSectionSize(70);  // 这里设置行高为50像素ui->tableView->horizontalHeader()->setStyleSheet("font-size:16pt;");//    ui->tableView->setStyleSheet(setcolor);ui->tableView->horizontalHeader()->setStyleSheet(setcolor);ui->tableView->horizontalHeader()->setMinimumHeight(50);ui->tableView->setSelectionMode(QAbstractItemView::ContiguousSelection);//多选ui->tableView->setSelectionBehavior(QAbstractItemView::SelectRows);//选中行ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);//不可编辑//    Commonstyle("tableView");//计算当前数据库一共有多少页updateTotalCount(mProxyModel->rowCount());on_pagehome();connect(ui->tableView->selectionModel(),SIGNAL(selectionChanged(const QItemSelection &, const QItemSelection &)),this,SLOT(slotSelectChanged(const QItemSelection &, const QItemSelection &)));}

二、创建弹窗控件,可以添加内容

//新建订单弹窗
void TestProSetWid::createdialog()
{newOrderDialog = new QDialog(this);newOrderDialog->setMinimumSize(500, 400);newOrderDialog->setMaximumSize(500, 400);newOrderDialog->setModal(true);QGridLayout *orderLayout = new QGridLayout();QHBoxLayout *btnLayout = new QHBoxLayout();QVBoxLayout *mainLayout = new QVBoxLayout();orderNumLabel    = new QLabel("单号:");typeLabel             = new QLabel("类型:");organizationLabel = new QLabel("单位:");testNumLabel      = new QLabel("编号:");orderNumEdit = new QLineEdit();typeEdit          = new QLineEdit();organizationEdit = new QLineEdit();testNumEdit      = new QLineEdit();orderNumEdit->setReadOnly(true); //只读orderNumLabel->setStyleSheet("color:white;");typeLabel->setStyleSheet("color:white;");organizationLabel->setStyleSheet("color:white;");testNumLabel->setStyleSheet("color:white;");orderNumEdit->setStyleSheet("background-color:white;" );typeEdit->setStyleSheet("background-color:white;");organizationEdit->setStyleSheet("background-color:white;");testNumEdit->setStyleSheet("background-color:white;");QFont font;font.setFamily("宋体");font.setPointSize(12);font.setBold(true);orderNumLabel->setFont(font);typeLabel->setFont(font);organizationLabel->setFont(font);testNumLabel->setFont(font);orderNumEdit->setFont(font);typeEdit->setFont(font);organizationEdit->setFont(font);testNumEdit->setFont(font);QPushButton *addBtn = new QPushButton("确认");QPushButton *cancelBtn = new QPushButton("取消");addBtn->setFixedSize(80,40);cancelBtn->setFixedSize(80,40);addBtn->setFont(font);cancelBtn->setFont(font);addBtn->setStyleSheet("background-color:rgb(48,176,226);border-radius:10px;");cancelBtn->setStyleSheet("background-color:rgb(48,176,226);border-radius:10px;");orderLayout->addWidget(orderNumLabel,0,0);orderLayout->addWidget(orderNumEdit,0,1);orderLayout->addWidget(typeLabel,1,0);orderLayout->addWidget(typeEdit,1,1);orderLayout->addWidget(organizationLabel,2,0);orderLayout->addWidget(organizationEdit,2,1);orderLayout->addWidget(testNumLabel,3,0);orderLayout->addWidget(testNumEdit,3,1);orderLayout->setVerticalSpacing(50);btnLayout->addWidget(addBtn);btnLayout->addWidget(cancelBtn);mainLayout->addLayout(orderLayout);mainLayout->addLayout(btnLayout);mainLayout->setStretch(0,1);mainLayout->setStretch(1,1);newOrderDialog->setLayout(mainLayout);connect(addBtn,SIGNAL(clicked()),this,SLOT(addbtn_clicked()));connect(cancelBtn, &QPushButton::clicked, this, [=](){// 关闭数据库的代码productDialog->close();});}

与确认按钮链接槽函数

//弹窗新建订单确认按钮
void TestProSetWid::addbtn_clicked()
{int row = dbmodel->rowCount();/* 写入数据到数据库 */dbmodel->insertRow(row);dbmodel->setData(dbmodel->index(row, 0), orderNumEdit->text());dbmodel->setData(dbmodel->index(row, 1), typeEdit->text());dbmodel->setData(dbmodel->index(row, 2), organizationEdit->text());dbmodel->setData(dbmodel->index(row, 3), testNumEdit->text());dbmodel->submit();/* 再确保提交 */if (dbmodel->isDirty())dbmodel->submitAll();newOrderDialog->close();updateTotalCount(dbmodel->rowCount());//当前页数函数//    ui->lineEdit_5->setText(QString("%1").arg(mTotalPage));on_pageend();//返回尾页函数
}


                                    

这篇关于在QT中使用QTableView与数据库连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/923454

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

【Altium】查找PCB上未连接的网络

【更多软件使用问题请点击亿道电子官方网站】 1、文档目标: PCB设计后期检查中找出没有连接的网络 应用场景:PCB设计后期,需要检查是否所有网络都已连接布线。虽然未连接的网络会有飞线显示,但是由于布线后期整板布线密度较高,虚连,断连的网络用肉眼难以轻易发现。用DRC检查也可以找出未连接的网络,如果PCB中DRC问题较多,查找起来就不是很方便。使用PCB Filter面板来达成目的相比DRC

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

数据库期末复习知识点

A卷 1. 选择题(30') 2. 判断范式(10') 判断到第三范式 3. 程序填空(20') 4. 分析填空(15') 5. 写SQL(25') 5'一题 恶性 B卷 1. 单选(30') 2. 填空 (20') 3. 程序填空(20') 4. 写SQL(30') 知识点 第一章 数据库管理系统(DBMS)  主要功能 数据定义功能 (DDL, 数据定义语

给数据库的表添加字段

周五有一个需求是这样的: 原来数据库有一个表B,现在需要添加一个字段C,我把代码中增删改查部分进行了修改, 比如insert中也添入了字段C。 但没有考虑到一个问题,数据库的兼容性。因为之前的版本已经投入使用了,再升级的话,需要进行兼容处理,当时脑子都蒙了,转不过来,后来同事解决了这个问题。 现在想想,思路就是,把数据库的表结构存入文件中,如xxx.sql 实时更新该文件: CREAT