当前位置: 首页 > news >正文

Qt扫盲-QSqlQueryModel理论总结

QSqlQueryModel理论总结

  • 一、概述
  • 二、使用
    • 1. 与 view 视图 绑定
    • 2. 分离视图,只存数据

一、概述

QSqlQueryModel是用于执行SQL语句和遍历结果集的高级接口。它构建在较低级的 QSqlQuery之上,可用于向QTableView 等视图类提供数据,也是使用了Qt 的 mode/view 框架。这种方式是非常快的,对于数据的显示是非常方便的一个类,而且这个类主要是用于对 sql 的查询,也就是只读的一个操作只读取数据,而不会修改数据的一个 model 类。

当然,在使用这些之前也是要连接数据库的,和正常使用 QSqlQuery 没有什么区别的。

二、使用

1. 与 view 视图 绑定

例如:

QSqlQueryModel *model = new QSqlQueryModel;
model->setQuery("SELECT name, salary FROM employee");
model->setHeaderData(0, Qt::Horizontal, tr("Name"));
model->setHeaderData(1, Qt::Horizontal, tr("Salary"));QTableView *view = new QTableView;
view->setModel(model);
view->show();

我们设置了模型的查询,然后设置了显示在视图标题中的标签。当然这个标签也是自己定义的,如果没有定义的话就会使用数据库中的表字段。

2. 分离视图,只存数据

QSqlQueryModel也可以通过编程方式访问数据库,而不需要将其绑定到视图:
在这个情况下,相当于我们通过model 去访问到了数据,避免直接与数据库去交互数据,在model 层的交互就非常的简单。

在这里插入图片描述

QSqlQueryModel model;
model.setQuery("SELECT name, salary FROM employee");
int salary = model.record(4).value("salary").toInt();

上面的代码片段从SELECT查询的结果集中的第4条记录中提取了salary字段。【要注意索引边界问题】

由于salary是第2列(或者列索引为1),我们可以将最后一行重写为:

 int salary = model.data(model.index(4, 1)).toInt();

通过这样的方式我们也非常方便的去读取了数据库的数据。

模型默认是只读的。要使它可读可写,必须继承它并重新实现setData()和flags()。另一种选择是使用QSqlTableModel,它提供了基于单个数据库表的读写模型。

http://www.lryc.cn/news/176266.html

相关文章:

  • 分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测(SE注意力机制)
  • 【单调栈】496. 下一个更大元素 I
  • 搭建Vue的开发环境,Edge浏览器安装VUE拓展工具
  • 14:00面试,14:06就出来了,这问的谁顶得住啊
  • python 探索分形世界|曼德布洛特|np.frompyfunc()
  • Android MVVM示例项目
  • 迅为龙芯2K1000开发板通过汇编控制GPIO
  • 合合信息、上海大学、华南理工大学发布业内首个古彝文编码“大字典” ,为古文字打造“身份证”
  • Django — 类视图和中间件
  • VMware安装CentOS Stream 8以及JDK和Docker
  • MySQL作业1
  • 基于微信小程序的家校通系统设计与实现(亮点:选题新颖、上传作业、批改作业、成绩统计)
  • uni-app问题记录
  • Leetcode---363周赛
  • Netty粘包与拆包问题
  • JS下载链接的两种方式
  • 手把手教你实现:将后端SpringBoot项目部署到华为云服务器上
  • 【红队攻防】从零开始的木马免杀到上线
  • Linux命令行操作:使用“more“命令进行分页显示
  • CentOS下安装MySQL 8.1及备份配置
  • 【RabbitMQ实战】06 3分钟部署一个RabbitMQ集群
  • (c语言)整形提升
  • 上传文件报错:The temporary upload location [/tmp/tomcat/xxx] is not valid
  • 直线模组的品牌有哪些?
  • 零基础学习ESP8266
  • 基于PYQT5的GUI开发系列教程【二】框架安装和基础环境配置
  • pg数据库操作,insert(sql)插入一条数据后获返回当前插入数据的id --chatGPT
  • 【数据结构-树】哈夫曼树
  • HarmonyOS 4.0 实况窗上线!支付宝实现医疗场景智能提醒
  • 【响应式布局】