QTableView实现在表格内直接对数据库内容进行修改、新增和删除等操作
前言
本文主要利用QSqlTableModel+QTableView来实现直接在QTableView中进行对数据库数据的操作
新增:点击新增按钮之后,光标直接移到最后一行,然后双击进行表内容的填充。
删除:选中一行之后,点击删除。
修改:选中一行,点击修改,此时表内容可修改。
提交:将进行的操作提交到数据库操作。
取消:取消操作。

QSqlTableModel
简易用法:
// QSqlTableModel(QObject*, QSqlDatabase)
m_sqlModel = new QSqlTableModel(this, m_access->m_sqlDatabase);
// setTable -> tableName 就是你要查询的表名
m_sqlModel->setTable("tableName");
// 设置为手动刷新,用来达到需要手动提交的效果
m_sqlModel->setEditStrategy(QSqlTableModel::OnManualSubmit);
新增
新增的主要逻辑是fetchMore到最后一行,然后再最后一行处添加一行空的数据,然后将表格设置为可编辑状态,然后再双击进行编辑
void ThresholdManage::on_btnNew_clicked()
{
// 设置编辑模式
// m_editMode是自定义变量,用于标识当前是否是编辑状态
m_editMode = true;
// 将其余功能按键禁用,将提交和取消启用
ui->btnEdit->setDisabled(true);
ui->btnNew->setDisabled(true);
ui->btnDelete->setDisabled(true);
ui->btnCancel->setEnabled(true);
ui->btnSubmit->setEnabled(true);
// m_sqlModel每次只能最大缓存256个,所以需要先fetchMore
// 否则会导致移动到最后一行时,只会最多移到256行
while (m_sqlModel->canFetchMore()) {
m_sqlModel->fetchMore();
}
int rowCount = m_sqlModel->rowCount();
// 在rowCount处添加一行
m_sqlModel->insertRow(rowCount);
m_sqlModel->setData(m_sqlModel->index(rowCount, 0), "");
// 设置双击编辑
ui->tableView->setEditTriggers(QTableView::DoubleClicked);
// 滚动到底部
ui->tableView->scrollToBottom();
}

删除
删除是直接removeRow,删除当前选中行,然后submitAll
void ThresholdManage::on_btnDelete_clicked()
{
// 找到当前行,然后removeRow
auto index = ui->tableView->currentIndex();
m_sqlModel->removeRow(index.row());
// 删除前,弹框确认
int ok = QMessageBox::warning(this, "删除当前行!", "确定删除当前行?", QMessageBox::Yes, QMessageBox::No);
if (ok == QMessageBox::No) {
m_sqlModel->revertAll();
return;
}
// 提交
m_sqlModel->submitAll();
// 查询
m_sqlModel->select();
}

修改
修改是将表格的编辑模式打开
void ThresholdManage::on_btnEdit_clicked()
{
// TODO
// 将其余按键状态置灰
m_editMode = true;
// 将表格的编辑模式打开
ui->tableView->setEditTriggers(QAbstractItemView::DoubleClicked);
ui->btnNew->setDisabled(true);
ui->btnNew->setDisabled(true);
ui->btnDelete->setDisabled(true);
ui->btnCancel->setEnabled(true);
ui->btnSubmit->setEnabled(true);
}

提交
提交是submitAll
void ThresholdManage::on_btnSubmit_clicked()
{
// TODO
// 刷新表格的内容
m_editMode = false;
// 提交弹框确认
int ok = QMessageBox::warning(this, "提交修改", "确定提交修改?", QMessageBox::Yes, QMessageBox::No);
if (ok == QMessageBox::No) {
qDebug() << "取消提交";
return;
}
// 提交修改
m_sqlModel->submitAll();
ui->btnNew->setEnabled(true);
ui->btnEdit->setEnabled(true);
ui->btnDelete->setEnabled(true);
ui->btnCancel->setDisabled(true);
ui->btnSubmit->setDisabled(true);
// 将表格置为不可修改
ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);
}

取消
取消是revertAll
void ThresholdManage::on_btnCancel_clicked()
{
// TODO
// 刷新表格的内容
m_editMode = false;
// 取消所有
m_sqlModel->revertAll();
ui->btnNew->setEnabled(true);
ui->btnEdit->setEnabled(true);
ui->btnDelete->setEnabled(true);
ui->btnCancel->setDisabled(true);
ui->btnSubmit->setDisabled(true);
ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);
}
代码如下:资源
刚刚发现这个资源我上传的时候我设置的不需要积分,但是后台自动给我加了积分…可以访问这个下载
QTableView实现在表格内直接对数据库内容进行修改、新增和删除等操作的更多相关文章
- C#使用Command将dataGrideView表格内数据与数据库交互
本文主要介绍通过Command类使用SQL插入指令insert与查询指令select将dataGrideView表格内添加至数据库,与从数据库读出数据存放在dataGrideView表格中. C#制作 ...
- 怎么把excel表格内的数据导入数据库?
第一种方法: 思路:想要把excel表格内的数据直接导入数据库不是那么容易,可以把excel表格另存为.csv格式的文档(特点:内容以逗号分割):然后通过一系列的文档操作函数处理成为一个二维数组,然后 ...
- Qt QTableView 表格内添加控件
目录 Qt QTableView 表格内添加控件 1. QItemDelegate 2. setIndexWidget 3. setIndexWidget + setLayout Qt QTableV ...
- jsp+oracle实现数据库内容以表格形式在前台显示(包含分页)
jsp+oracle实现数据库内容以表格形式在前台显示(包含分页) 在文件夹内新增list_emp.jsp 代码如下: <%@ page contentType="text/html& ...
- Linqpad使用(调试Linq、结合linq调试业务场景、表格内编辑数据)
linqpad是一款linq语句调试工具,功能如下: 1.直接执行linq语句并查看生成的原生sql语句 2.可结合linq+C#代码进行业务场景调试 3.表格内直接新增.修改.删除数据 4.直接 ...
- 如何将Excl内数据导入数据库?
最近有个Excl表格内的数据需要导入SQL Server数据库内,使用SQL Server Management Studio客户端图形界面操作了一番,步骤还挺多,感觉有必要分享给大家一下,顺便自己也 ...
- Latex 表格内公式换行方法
Latex 表格内的公式实现换行的方法 简单的两步走: 1.先将下面的语句放在latex正文的导言区: \newcommand{\tabincell}[2]{\begin{tabula ...
- 外网访问内网MariaDB数据库
外网访问本地MariaDB数据库 本地安装了MariaDB数据库,只能在局域网内访问,怎样从公网也能访问内网MariaDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Mar ...
- 怎样从外网访问内网Memcached数据库
外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...
- 怎样从外网访问内网CouchDB数据库
外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...
随机推荐
- ubuntu安装ps命令
docker容器是debian的镜像,没有ps命令,查个进程没法查. 安装procps包 apt-get install procps
- 操作系统messages文件位置更改
问题现象 在遇到一个问题的时候需要查看操作系统的日志,但是到操作系统上的 /var/log/messages 文件中发现该文件已经很久没有刷新过了. 这个系统之前是做过安全加固的,我怀疑它改过操作系统 ...
- Qt音视频开发40-ffmpeg采集桌面并录制
一.前言 之前用ffmpeg打通了各种视频文件和视频流以及本地摄像头设备的采集,近期有个客户需求要求将整个桌面屏幕采集下来,并可以录制保存成MP4文件,以前也遇到过类似的需求,由于没有搞过,也没有精力 ...
- Qt数据库应用22-文件编码格式识别
一.前言 在做数据导入导出的过程中,如果应用场景多了,相信各位都会遇到一个问题就是文件编码的问题,有些文件是ANSI编码,有些是utf8编码,有些又是utf8带bom编码,不同的文件编码如果都用同一种 ...
- [转]GMM:高斯混合模型讲义(台湾)
- [炼丹术]YOLOR目标检测训练模型学习总结
YOLOR目标检测训练模型学习总结 性能测试 python test.py --data data/cocoaml --img 320 --batch 8 --conf 0.001 --iou 0.6 ...
- 【漏洞分析】20250105-SorraStaking:奖励金额计算错误,每次取款都有大收益
背景信息 2024-12-21 11:58:11 (UTC) 准备交易:https://app.blocksec.com/explorer/tx/eth/0x72a252277e30ea6a37d2d ...
- linux进入横线 "-" 开头的文件夹
在linux进行文件操作时,会遇到一类文件是以"-"开头的. 例如我们想要进入名称为-126943579的文件时,我们无法直接使用cd -126943579命令来进入该文件. 那我 ...
- 「规则类怪谈」塔 - (preview)
前段时间,大概五六月份,我很喜欢规则类怪谈.颓废的时候读了一大堆质量参差不齐的作品,试着编了一个世界观然后开写.咕着咕着磨到现在,至少情节大概成形了.最大的阻力在于物理规则的完备性和自洽性,为什么 ...
- Quartz调度框架详解、运用场景、与集群部署实践
以下将分别从Quartz架构简介.集群部署实践.Quartz监控.集群原理分析详解Quartz任务调度框架. Quartz简介 Quartz是Java领域最著名的开源任务调度工具,是一个任务调度框架, ...