QT的数据库操作有两种方式: 一) 使用QsqlTableModel类, 可以配合QTableView进行界面显示并进行数据库操作,

这种方法比较方便快捷; 二)  使用原始SQL语言, 利用INSERT, UPDATE, SELECT, DELETE实现插入,更新,查询,删除功能;

1) QSqlTableModel类的使用;

    QSqlDatabase db;                   //数据库要打开;
QString szTable = "test"; //数据表名;
m_pSqlTableModel = new QSqlTableModel(this, db); // bind tableView;
m_pSqlTableModel->setEditStrategy(QSqlTableModel::OnManualSubmit); //有三种编写模式;
m_pSqlTableModel->setTable(szTable);     //指定数据表;
m_pSqlTableModel->setFilter("id = 1"); //where条件;
m_pSqlTableModel->select(); //相当于SQL语言 select;

  1、添加记录;

int nRowNum = m_sqlTableModel->rowCount();      //记录数;
QSqlRecord record = m_sqlTableModel->record(); //
m_sqlTableModel->setRecord(nRowNum, record);
if( !m_sqlTableModel->submitAll() )
{
qDebug() <<"submit error";
}

   2、修改记录;

QSqlTableModel *pMode = dynamic_cast<QSqlTableModel *>(ui->tableView->model());
pMode->database().transaction(); //开始事务操作
if (pMode->submitAll()) // 提交所有被修改的数据到数据库中
{
pMode->database().commit(); //提交成功,事务将真正修改数据库数据
} else {
pMode->database().rollback(); //提交失败,事务回滚
QMessageBox::warning(this, tr("tableModel"),tr("数据库错误: %1").arg(pMode->lastError().text()));
}
pMode->revertAll(); //撤销修改

  3、查询记录;

m_pSqlTableModel->setFilter("id= 1");
m_pSqlTableModel->select(); //查询;

4、删除记录;

//  实现多行删除;    删除的关键函数 removeRow
QItemSelectionModel *pSelectModel = ui->tableView->selectionModel();
QModelIndexList indexList = pSelectModel->selectedIndexes(); //被选择的;
QMap<int,int>rowMap;
foreach (QModelIndex index, indexList)
{
if(! index.isValid()) return;
if(index.column()!=0) continue;
rowMap.insert(index.row(),0);
}
QMapIterator<int,int> rowMapIterator(rowMap);              //如果要删除多行, 直接一行一行的删除会出现位置的移动, 这里通过将所有的要删除的行保存起来,按照从后往前的方法进行删除, 这样就解决了位置移动导致的删除错误;
rowMapIterator.toBack();
while(rowMapIterator.hasPrevious())
{
rowMapIterator.previous();
int rowm=rowMapIterator.key();
m_pSqlTableModel->removeRow(rowm);
}
m_pSqlTableModel->submitAll();
m_pSqlTableModel->select();

 QItemSelectionModel是QTableView的选取封装类,通过该类可以方便的获取当前选取的区域;

2) 原始SQL语句的使用;

略;

 

注: 该博文为扩展型;

Qt: 数据库操作;的更多相关文章

  1. 2.大约QT数据库操作,简单的数据库连接操作,增删改查数据库,QSqlTableModel和QTableView,事务性操作,大约QItemDelegate 代理

     Linux下的qt安装,命令时:sudoapt-get install qt-sdk 安装mysql数据库,安装方法參考博客:http://blog.csdn.net/tototuzuoquan ...

  2. qt 数据库操作总结

    #include <QtSql>QT += sql QSqlDatabase类实现了数据库连接的操作QSqlQuery类用来执行SQL语句QSqlRecord类 封装数据库所有记录 第一: ...

  3. Qt数据库操作(qt-win-commercial-src-4.3.1,VC6,Oracle,SQL Server)

    qt-win-commercial-src-4.3.1.qt-x11-commercial-src-4.3.1Microsoft Visual C++ 6.0.KDevelop 3.5.0Window ...

  4. QT数据库操作

    浏览: 在QSqlQuery类中当执行exec()后会把指针放在记录集中第一个记录之上,所以需要调用QSqlQuery::next()来获取第一个数据,下面通过循环体来遍历所有表中的数据. while ...

  5. Qt数据库_资料

    1. QT笔记_数据库总结(一)-rojian-ChinaUnix博客.html http://blog.chinaunix.net/uid-28194872-id-3631462.html (里面有 ...

  6. Qt之操作数据库(SQLite)

    SQLite 简介 SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需 ...

  7. qt 5 数据库操作(mysql)

    其实大家都知道,QT5以上的都自带了数据库驱动,所以呢,基本上可以直接使用,于是如果想知道怎么连接数据库,请参考这位大神写的.http://qtdebug.com/DB-AccessMySQL.htm ...

  8. Qt 多线程与数据库操作需要注意的几点问题(QSqlDatabase对象只能在当前线程里使用)

    彻底抛弃MFC, 全面应用Qt 已经不少时间了.除了自己看书按步就班做了十几个验证性的应用,还正式做了3个比较大的行业应用,总体感觉很好.Native C++ 下, Qt 基本是我用过的最简便的界面库 ...

  9. Qt 多线程与数据库操作需要注意的几点问题

    源地址:http://blog.csdn.net/goldenhawking/article/details/10811409 彻底抛弃MFC, 全面应用Qt 已经不少时间了.除了自己看书按步就班做了 ...

随机推荐

  1. VS2017在线安装包下载

    VS2017个人免费版即社区官方下载地址为:https://download.microsoft.com/download/D/1/4/D142F7E7-4D7E-4F3B-A399-5BACA91E ...

  2. jenkins自动化工具使用教程(转)

    自动化构建.测试.部署.代码检测越来越重要.主要有一下几点原因 企业做大,项目变多,多端支持(web,h5,小程序等) 微服务提倡高内聚低耦合,项目因拆分变多 DevOps自动化运维流行 集群化,高可 ...

  3. centos7配置静态ip地址

    1.配置文件所在目录为 /etc/sysconfig/network-scripts cd /etc/sysconfig/network-scripts 2.打开配置文件进行修改,建议在修改之前先备份 ...

  4. kernel笔记——块I/O

    Linux下,I/O处理的层次可分为4层: 1. 系统调用层,应用程序使用系统调用指定读写哪个文件,文件偏移是多少  2. 文件系统层,写文件时将用户态中的buffer拷贝到内核态下,并由cache缓 ...

  5. zookeeper安装教程(zookeeper3.4.5为例)

    zookeeper有单机.伪集群.集群三种部署方式,可根据自己对可靠性的需求选择合适的部署方式.下边对这三种部署方式逐一进行讲解. 一.单机安装 1.1 下载 进入要下载的版本的目录,选择.tar.g ...

  6. [LeetCode] 6. Z 字形变换

    题目链接:(https://leetcode-cn.com/problems/zigzag-conversion/) 题目描述: 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列 ...

  7. fliplr函数

    fliplr  左右翻转矩阵 语法: B = fliplr(A) 将矩阵A的列绕垂直轴进行左右翻转 matabc 如果A是一个行向量,fliplr(A)将A中元素的顺序进行翻转. 如果A是一个列向量, ...

  8. 机器人行业中我们常说的roll、yaw、pitch是什么?

    坐标系建立: 载体坐标系与载体坐标系的关系是三个Euler角:yaw,pitch,roll,反应了载体相对基准面的姿态. pitch是围绕X轴旋转,也叫做俯仰角.当X轴的正半轴位于过坐标原点的水平面之 ...

  9. SpringBoot中各配置文件的优先级及加载顺序

    我们在写程序的时候会碰到各种环境(开发.测试.生产),因而,在我们切换环境的时候,我们需要手工切换配置文件的内容.这大大的加大了运维人员的负担,同时会带来一定的安全隐患. 为此,为了能更合理地重写各属 ...

  10. 基于 WebGL 的 HTML5 楼宇自控 3D 可视化监控

    前言 智慧楼宇和人们的生活息息相关,楼宇智能化程度的提高,会极大程度的改善人们的生活品质,在当前工业互联网大背景下受到很大关注.目前智慧楼宇可视化监控的主要优点包括: 智慧化 -- 智慧楼宇是一个生态 ...