QSqlTableModel类继承至QSqlQueryModel类,该类提供了一个可读写单张SQL表的可编辑数据模型,功能:修改,插入,删除,查询,和排序

常用函数

QVariant headerData ( int section,Qt::Orientation orientation, int role = Qt::DisplayRole ) const  获取水平头或垂直头标题

bool setHeaderData ( int section,Qt::Orientation orientation, const QVariant & value, int role = Qt::EditRole ) 设置水平头或垂直头标题

int rowCount ( const QModelIndex & parent= QModelIndex() ) const // 返回行数

int columnCount ( const QModelIndex &index = QModelIndex() ) const // 返回列数

virtual bool removeColumns ( int column, int count, const QModelIndex & parent = QModelIndex() ) //model->removeColumns (0)删除第一列

bool QSqlTableModel::submitAll (),//提交所有被修改的数据,然后修改的数据被保存在数据库中

void QSqlTableModel::revertAll ()  //撤销所有的修改,如果数据库已经被提交了修改,就不能通过撤销修改改回来了

virtual void revertRow ( int row ) //恢复指定行的改变

void QSqlTableModel::setFilter ( const QString & filter )  //筛选,按照字符串filter对数据库进行筛选,相当于SQL中的WHERE语句

bool QSqlTableModel::select ()   //在筛选和排序的条件下,将数据库中符合要求的在mode表格中显示出来

void QSqlTableModel::setSort ( int column, Qt::SortOrder order ) //排序操作。按照列和Qt::SortOrder排序。Qt::SortOrder有升序和降序

bool insertRow ( int row, const QModelIndex & parent = QModelIndex() )  //插入行

bool insertColumn ( int column, constQModelIndex & parent = QModelIndex() ) // 插入列

model->setEditStrategy(QSqlTableModel::OnManualSubmit);   //设置保存策略为手动提交

一、在QTableView中显示数据库中表的数据

  1. QSqlTableModel *model = new QSqlTableModel(parentObject, database); // 摘抄自帮助文档
  2. model->setTable("employee");
  3. model->setEditStrategy(QSqlTableModel::OnManualSubmit);
  4. model->select();
  5. model->removeColumn(0); // don't show the ID
  6. model->setHeaderData(0, Qt::Horizontal, tr("Name"));
  7. model->setHeaderData(1, Qt::Horizontal, tr("Salary"));
  8. QTableView *view = new QTableView;
  9. view->setModel(model);
  10. view->show();

二、修改QTableView中数据后的提交,加入事务处理

  1. model->database().transaction(); //开始事务操作
  2. if (model->submitAll()) // 提交所有被修改的数据到数据库中
  3. {
  4. model->database().commit(); //提交成功,事务将真正修改数据库数据
  5. } else {
  6. model->database().rollback(); //提交失败,事务回滚
  7. QMessageBox::warning(this, tr(“tableModel”),tr(“数据库错误: %1″).arg(model->lastError().text()));
  8. }
  9. model->revertAll(); //撤销修改

三、查询操作

相当于SQL语句:SELECT * FROM 表名 WHERE name = "name变量"

  1. model->setFilter(QObject::tr(“name = ‘%1′”).arg(name)); //根据姓名进行筛选
  2. model->select(); //显示结果
  3. for (int i = 0; i < model.rowCount(); ++i)
  4. {
  5. QString name = model.record(i).value("name").toString();
  6. // ... 在此处理每一条的记录
  7. }
  8. // 在操作大数据集时,建议通过索引指定字段
  9. int primaryKeyIndex  = model.record().indexOf("id");
  10. for (int i = 0; i < model.rowCount(); ++i)
  11. {
  12. QSqlRecord record = model.record(i);
  13. QString name = record.value("name").toString();
  14. // ... 在此处理每一条的记录
  15. }

四、排序操作

  1. model->setSort(0,Qt::AscendingOrder); //id属性,即第0列,升序排列,Qt::DescendingOrder为降序排序
  2. model->select();

五、插入操作

  1. int rowNum = model->rowCount(); //获得表的行数
  2. int id = 最后一个ID+1;
  3. model->insertRow(rowNum); //添加一行,或者用insertRows(0,1),在0行添加1条记录,根据表的排序规则,可能移到与指定行不同的行位置上
  4. model->setData(model->index(rowNum,0),id);  //因为这里设置了ID为主键,所以必须给新行添加id属性值,id字段在第0列上
  5. model->submitAll(); //可以直接提交

六、删除一条记录

首先要定位到待删除的行上

  1. model.setFilter("id = 10");
  2. model.select();
  3. if (model.rowCount() == 1)
  4. {
  5. model.removeRows(0,1) // 如果要删除所有满足条件的记录则把1改成model.rowCount()
  6. model.submitAll();
  7. }

在QTableView中删除选中的一行

  1. int curRow = tableView->currentIndex().row();
  2. model->removeRow(curRow);   //删除一行

在QTableView中删除选中的多行

QAbstractItemView::SelectionModeselectionMode()const
// 原型

QModelIndexListQItemSelectionModel::selectedIndexes()const 
//原型

  1. QItemSelectionModel *selections = tableView->selectionModel(); //返回当前的选择模式
  2. QModelIndexList selecteds = selections->selectedIndexes(); //返回所有选定的模型项目索引列表
  3. foreach (QModelIndex index, selecteds)
  4. {
  5. int curRow = index.row(); //删除所有被选中的行
  6. model->removeRow(curRow);
  7. }
  8. int ok = QMessageBox::warning(this,tr("删除选中的行!"),tr("你确定删除当前选取中的行吗?"),QMessageBox::Yes,QMessageBox::No);
  9. if(ok == QMessageBox::Yes)
  10. {
  11. model->submitAll(); //提交,在数据库中删除该行
  12. } else {
  13. model->revertAll(); //如果不删除,则撤销
  14. }

七、更新记录

必须先定位记录

  1. model.setFilter("id = 10");
  2. model.select();
  3. if (model.rowCount() == 1)
  4. {
  5. model.setData(model.index(0,1),QObject::tr("小王"));
  6. model.submitAll();
  7. }

可以看到这个模型很强大,而且完全脱离了SQL语句,就算你不怎么懂数据库,也可以利用它进行大部分常用的操作。这个模型提供了缓冲区,可以将所有修改先
保存到model中,只有当我们执行提交修改后,才会真正写入数据库。当然这也是因为我们在最开始设置了它的保存策略:

model->setEditStrategy(QSqlTableModel::OnManualSubmit);

OnManualSubmit表明我们要提交修改才能使其生效。可以先将修改保存起来,当我们执行提交函数时,再去真正地修改数据库。当然,这个模型比前面的模型更高级,前面讲的所有操作,在这里都能执行。

QT笔记:数据库总结(三)之SQL模型类-QSqlTableModel模型的更多相关文章

  1. QT笔记:数据库总结

    http://blog.csdn.net/reborntercel/article/details/6991147 #include <QtSql> QT += sql QSqlDatab ...

  2. QtSQL学习笔记(4)- 使用SQL Model类

    除了QSqlQuery,Qt提供了3个高级类用于访问数据库.这些类是QSqlQueryModel.QSqlTableModel和QSqlRelationalTableModel. 这些类是由QAbst ...

  3. Qt笔记——数据库的图形界面

    1将读取的数据通过表格的方式显示出来 #ifndef WIDGET_H #define WIDGET_H #include <QWidget> #include <QSqlTable ...

  4. Flask之自定义模型类

    4.3自定义模型类 定义模型 模型表示程序使用的数据实体,在Flask-SQLAlchemy中,模型一般是Python类,继承自db.Model,db是SQLAlchemy类的实例,代表程序使用的数据 ...

  5. Python实现一个ORM模型类

    ORM是三个单词首字母组合而成,包含了Object(对象-类),Relations(关系),Mapping(映射).解释过字面意思,但ORM的概念仍然模糊.私以为要理解一个事物,最好的法子是搞明白它出 ...

  6. ThinkPHP 学习笔记 ( 三 ) 数据库操作之数据表模型和基础模型 ( Model )

    //TP 恶补ing... 一.定义数据表模型 1.模型映射 要测试数据库是否正常连接,最直接的办法就是在当前控制器中实例化数据表,然后使用 dump 函数输出,查看数据库的链接状态.代码: publ ...

  7. Qt 学习之路 2(56):使用模型操作数据库

    Qt 学习之路 2(56):使用模型操作数据库 (okgogo: skip) 豆子 2013年6月20日 Qt 学习之路 2 13条评论 前一章我们使用 SQL 语句完成了对数据库的常规操作,包括简单 ...

  8. 学习笔记:oracle学习三:SQL语言基础之sql语言简介、用户模式

    目录 1.sql语言简介 1.1 sql语言特点 1.2 sql语言分类 1.3 sql语言的编写规则 2.用户模式 2.1 模式与模式对象 2.2 实例模式scott 本系列是作为学习笔记,用于记录 ...

  9. 数据库整理(三) SQL基础

    数据库整理(三) SQL基础 SQL语言的特点 集数据定义语言(DDL),数据操纵语言(DML),数据控制语言(DCL)功能于一体. 可以独立完成数据库生命周期中的全部活动: ​ ●定义和修改.删除关 ...

随机推荐

  1. ref:LDAP入门

    ref:https://www.jianshu.com/p/7e4d99f6baaf LDAP入门 首先要先理解什么是LDAP,当时我看了很多解释,也是云里雾里,弄不清楚.在这里给大家稍微捋一捋. 首 ...

  2. RTSP 资料

    分享两个不错的播客. http://blog.csdn.net/u010425035/article/details/10410851 http://blog.csdn.net/xiaoyafang1 ...

  3. [CodeForces-606E] Freelancer's Dreams 凸包 模型转换

    大致题意: 有一个人想要获得p个经验点和q元钱.现在给出n份工作,每份工作每天能得到Ai的经验值和Bi的钱,问最少需要工作多少天, 能使得总经验值>=p,总钱>=q. 先对给出的n份工作以 ...

  4. CF687B Remainders Game

      题意:已知n个数,第i个为ci,给定一个数x mod ci的结果,再给点一个k,问能不能知道x mod k的值? 分析:刚看题目的我一脸蒙蔽,对题意有点不理解,能的情况似乎有很多,我该从哪里下手呢 ...

  5. iOS系统中导航栏的转场解决方案与最佳实践

    背景 目前,开源社区和业界内已经存在一些 iOS 导航栏转场的解决方案,但对于历史包袱沉重的美团 App 而言,这些解决方案并不完美.有的方案不能满足复杂的页面跳转场景,有的方案迁移成本较大,为此我们 ...

  6. 1025 PAT Ranking (25)(25 point(s))

    problem Programming Ability Test (PAT) is organized by the College of Computer Science and Technolog ...

  7. [BZOJ4372]烁烁的游戏(动态点分治+线段树)

    和[BZOJ3730]震波几乎一样,每个点建两棵线段树分别代表它的管辖范围内以它为LCA的路径的贡献和它对父亲的贡献. 注意点分树上的点的距离在原树上不单调,所以不能有若距离超出限制就break之类的 ...

  8. 认识javascript中的作用域和上下文

    javascript中的作用域(scope)和上下文(context)是这门语言的独到之处,这部分归功于他们带来的灵活性.每个函数有不同的变量上下文和作用域.这些概念是javascript中一些强大的 ...

  9. ListView实现下拉刷新功能

    很久没有写博客了,感觉都懒惰了,今天说一下一个自定义的空间,就是ListView下拉列表可以刷新的功能,相信很多同学都看到过这种功能,最典型的就是新浪微博的下拉刷新列表了. 废话不多说,首先呢,下拉刷 ...

  10. My安装EclipseJS代码提示(Spket插件)

    最近须要大量使用JS来开发,可是MyEclipse2014自带的JS编辑器没有代码提示的功能,开发效率有点低,所以安装了一个Spket的插件,过程很easy,SVN插件的安装比这个更简单. Spket ...