我们在显示报表时可以用到上面两个类来实现,QTableView负责对视图显示;QSqlqueryModel则负责数据模块。

这里数据查询使用QSqlqueryModel主要是这个类可以通过自己写的查询语句来获得数据模型。

本文不对整个的流程作详细讲述,对本人在开发过程中遇到的一些点进行阐述

获得数据模型

QSqlQueryModel *Model = new QSqlQueryModel;
QString selectfromtable = "查询语句";
Model->setQuery(selectfromtable);

对表头名称进行修改,这里使用QString::fromLocal8Bit()是用于解决中文乱码问题的

Model->setHeaderData(0,Qt::Horizontal,QString::fromLocal8Bit("姓名"));
Model->setHeaderData(1,Qt::Horizontal,QString::fromLocal8Bit("证件号码"));
Model->setHeaderData(2,Qt::Horizontal,QString::fromLocal8Bit("性别"));
Model->setHeaderData(3,Qt::Horizontal,QString::fromLocal8Bit("配偶姓名"));
Model->setHeaderData(4,Qt::Horizontal,QString::fromLocal8Bit("子女数"));
Model->setHeaderData(5,Qt::Horizontal,QString::fromLocal8Bit("户籍地"));
Model->setHeaderData(6,Qt::Horizontal,QString::fromLocal8Bit("现居地"));
Model->setHeaderData(7,Qt::Horizontal,QString::fromLocal8Bit("出生日期"));
Model->setHeaderData(8,Qt::Horizontal,QString::fromLocal8Bit("婚姻状况"));
Model->setHeaderData(9,Qt::Horizontal,QString::fromLocal8Bit("是否标记离开"));

因为在对报表处理时,我们一般会在报表的每一列后面添加一些操作,这里在报表最后添加两列分别为编辑和删除

    Model->insertColumn(10);//这里是在模型的第十列后面插入一列
Model->setHeaderData(10,Qt::Horizontal,QString::fromLocal8Bit("查看"));
Model->insertColumn(11);
Model->setHeaderData(11,Qt::Horizontal,QString::fromLocal8Bit("删除"));

将数据模型与TableView绑定,因为我们得到的数据是列的宽度是不一样的,但tableview默认是给一个固定宽度,这里我们使用resizeColumnsToContents()使列宽跟随内容改变。

使用resizeRowsToContents()则可使行高根据数据内容改变。

ui.tableVieW->setModel(Model);
ui.tableVieW->resizeColumnsToContents();

得到的效果如下图



可以看到最后面的两个按钮不是很理想,这时我们可以单独取出这两列对其列宽进行修改,只是修改按钮属性是不行的

代码如下

ui.tableVieW->setColumnWidth(10,50);
ui.tableVieW->setColumnWidth(11,50);

得到的效果如下

初学Qt——QTableView+QSqlqueryModel的更多相关文章

  1. Qt QTableView 表格内添加控件

    目录 Qt QTableView 表格内添加控件 1. QItemDelegate 2. setIndexWidget 3. setIndexWidget + setLayout Qt QTableV ...

  2. QT QSqlQuery QSqlQueryModel

      SQL执行操作 QSqlQuery提供了对数据库记录的Select.Insert.Update.Delete操作. SELECT操作: QSqlQuery query; query.exec(&q ...

  3. QT QTableView用法小结

    QTableView常用于实现数据的表格显示.下面我们如何按步骤实现学生信息表格: 一 添加表头 //准备数据模型 QStandardItemModel *student_model = new QS ...

  4. Qt QtableView使用

    ui->setupUi(this); ui->mainToolBar->hide(); tableView = new QTableView(this); // 设置表头 QStan ...

  5. 【转载】QT QTableView用法小结

    原始日期: 2016-08-16 09:28 来源:http://blog.csdn.net/wang_lichun/article/details/7805253 QTableView常用于实现数据 ...

  6. 转载:QT QTableView用法小结

    出自: http://blog.chinaunix.net/uid-20382483-id-3518513.html QTableView常用于实现数据的表格显示.下面我们如何按步骤实现学生信息表格: ...

  7. qt qtableview 样式设置

    转载请注明出处:http://www.cnblogs.com/dachen408/p/7531159.html 1.设置tableview的列宽时,必须先setModel再setColumnWidge ...

  8. qt QTableView中嵌入复选框CheckBox 的四种方法总结

    第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四种比较适合扩展,它除了可以嵌入复选框,还可以通过paint()绘制其它控件 ...

  9. Qt ------ QTableView QTableWidget

    QTableView model提供数据    view提供视图   view用来显示model的数据   必须将model绑定到某个view中才能显示 QStandardItemModel* mod ...

随机推荐

  1. ios 获取app版本号

    let infoDictionary = Bundle.main.infoDictionary!let appversion = infoDictionary["CFBundleShortV ...

  2. iOS 部分API理解

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...

  3. NOIP2000提高组T1 进制转换

    https://www.luogu.org/problem/P1017 题目描述 我们可以用这样的方式来表示一个十进制数: 将每个阿拉伯数字乘以一个以该数字所处位置的值减1为指数,以10为底数的幂之和 ...

  4. 如何编译(helloworld)可以在开发板上运行的应用

    本节介绍如何编译可以在开发板上运行的应用,编译方法很简单.基于:iTOP4412开发板首先要确定一下环境变量,如下图所示,使用“cd”命令回到根目录,然后使用命令“vim .bashrc”打开环境变量 ...

  5. SAP PM:通过接口获取设备资产基本信息

    在SAP工厂维护模块中,给设备贴二维码标签是现在越来越流行的做法.因此通过扫描二维码获取设备资产信息是个非常基本的需求. 以下实例简单实现了,给SAP RFC传入设备编码获取设备资产基本信息的需求. ...

  6. 跨域问题与SpringBoot解决方案

    什么是跨域? 定义:浏览器从一个域名的网页取请求另一个域名下的东西.通俗点说,浏览器直接从A域访问B域中的资源是不被允许的,如果想要访问,就需要进行一步操作,这操作就叫"跨域".例 ...

  7. Office 365管理员设置

    一.注册 1.输入网站 http://www.21vbluecloud.com/  ,进入世纪互联蓝云官方网站 2.选择 运营的产品->Office 365 3.选择了解更多 4.浏览根据不同的 ...

  8. django框架基础-框架介绍-长期维护

    ###############    MVC架构介绍    ################ # MVC架构 # 一个软件框架有很多的模块,每一个模块有不同的功能 # 模块与模块之间相互配合来完成软件 ...

  9. react项目中引入了redux后js控制路由跳转方案

    如果你的项目中并没有用到redux,那本文你可以忽略 问题引入 纯粹的单页面react应用中,通过this.props.history.push('/list')就可以进行路由跳转,但是加上了redu ...

  10. 17)将index.php中的代码放到Framework中封装起来

    目录结构: 发生改动的类代码: 新增类:Framework.class.php <?php /** * Created by PhpStorm. * User: Interact * Date: ...