一、概述

Qt提供了一个类似JDBC的数据库接口,需要为每个可以连接的特定数据库提供驱动程序,可以通过 QStringList QSqlDatabase::drivers() 知道当前版本的Qt哪些驱动程序是可用的。

Qt可以连接各种不同的数据库,比如MySql、Oracle等等。在这里,我们将主要讨论Qt连接它自带的SQLite数据库。

二、从Qt连接数据库

先思考一下我们使用数据库通常会有哪些操作——

  • 连接数据库
  • 定义(或创建)数据库中的一个表
  • 插入一行(以及更新行、删除行)
  • 查询

OK,下面来一一解决这些问题。

1.连接数据库

连接数据库需要这些信息:驱动程序类型、主机名、用户名、密码、数据库名称。

我们使用QSqlDatabase这个类,它表示一个到数据库的连接。

bool DbModule::createConn()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName(m_strDbPath);
//db.setHostName("localhost");
//db.setUserName("");
//db.setPassword("");
if (db.open())
{
qDebug() << "Connected successfully.";
}
else
{
qDebug() << "Can't connect to database.";
qDebug() << "The error is: " << db.lastError().databaseText();
return false;
}
return true;
}

首先指定数据库驱动,我们使用Qt自带的SQLite。

接下来 setDatabaseName() 指定要使用的数据库,参数是数据库的路径,如果不存在,将会在参数指定的路径中新建一个。

因为SQLite是Qt自带的,所以不需要服务器,也不需要配置用户名和密码。设置或不设置这几项没有任何作用。(我的疑问是,这会有安全隐患吗)

2.创建表

比如创建一个叫做personInfo的表,其中包含3个字段,分别是id、姓名name、工作job:

bool DbModule::createTable()
{
QString strQuery;
strQuery = "create table personInfo("
"id integer primary key,"
"name varchar(30), job varchar(30))";
QSqlQuery query;
if (query.exec(strQuery))
{
qDebug() << "Create Table Successfully.";
}
else
{
qDebug() << "Create Table Failed";
qDebug() << "The error is: " << query.lastError().databaseText();
return false;
}
return true;
}

使用QSqlQuery这个类来执行SQL语句,在这里我们并没有指定数据库,所以系统默认使用之前打开的那个数据库。

QSqlQuery::lastError() 用来帮助我们发现错误发生在哪里。

3.插入一行数据

bool DbModule::insertData(QString id, QString name, QString job)
{
QSqlQuery query;
query.prepare("insert into personInfo (name, job) values(:name, :job)");
query.bindValue(":name", name);
query.bindValue(":job", job);
if (query.exec())
{
qDebug() << "Insert Successfully.";
}
else
{
qDebug() << "Insert failed.";
qDebug() << "The error is: " << query.lastError().databaseText();
return false;
}
return true;
}

首先定义QSqlQuery。然后调用 prepare() 方法,可以使用纯SQL语句,或者为一些变量设置占位符,占位符必须以冒号:开始。接下来调用 bindValue() ,用合适的值填充那些占位符的地方。准备好之后,再执行这条SQL语句。

在这里并没有指定字段id对应的值,因为它被设置成了primary key。

我们还可以用下面的方法来准备SQL语句:

query.prepare("insert into personInfo (name, job) values(?, ?)");
query.addBindValue(name);
query.addBindValue(job);

使用问号?来占位,然后调用 addBindValue() 逐个设置占位的值。

4.查询

读出表中所有人及其对应的工作:

void DbModule::readData()
{
QSqlQuery query;
query.exec("select name, job from personInfo");
while (query.next())
{
QString name = query.value(0).toString();
QString job = query.value(1).toString();
qDebug() << "The job of " << name.toStdString().c_str() << " is " << job.toStdString().c_str();
}
}

使用 next() 遍历查询的结果,然后使用 value() 获取查询到的值,参数指定select语句对应的字段。

除此之外,还有删除、更新、删掉整个表等更多复杂的操作,只需要修改相应的SQL语句就行了,这里不再赘述。

Qt——数据库编程的更多相关文章

  1. Qt数据库编程1

    Qt中数据编程主要分为以下两点:1.利用qt提供类 访问数据库或者成为简单的数据库编程2.数据库编程中引入model/view编程模型 qt中数据库编程的步骤: 1.加载数据库驱动 QSqlDatab ...

  2. QT 数据库编程三

    //mainwindow.cpp #include "mainwindow.h" #include "logindlg.h" #include "sc ...

  3. Qt数据库编程_基本

    QtSql模块提供了一个平台无关且数据库无关的访问SQL数据库的接口. Qt中的每个数据库连接用一个QSqlDatabase对象来表示:Qt使用不同driver来和各种不同数据库的API进行通讯. Q ...

  4. QT 数据库编程四

    //vmysql.cpp #include "vmysql.h" #include <QMessageBox> Vmysql::Vmysql() { mysql_ini ...

  5. QT 数据库编程二

    //logindlg.cpp #include "logindlg.h" #include <QGridLayout> #include <QHBoxLayout ...

  6. QT基于model/view数据库编程2

    Qt中数据编程主要分为以下两点:1.利用qt提供类 访问数据库或者成为简单的数据库编程2.数据库编程中引入model/view编程模型 基于model/view数据库编程: qt提供model类: Q ...

  7. c++学习书籍推荐《C++ GUI Qt 4编程(第2版)》下载

    下载地址:点我 百度云及其他网盘下载地址:点我 编辑推荐 <C++ GUI Qt 4编程(第2版)>讲授的大量Qt4编程原理和实践,都可以轻易将其应用于Qt4.4.Qt4.5及后续版本的Q ...

  8. (九)文档和视图,Invalidate,数据库编程

    一.文档视图结构 文档类(CDocument):存储加载(读写)数据视图类(CView):显示和修改数据 1)单文档 a)文档模板:把框架窗口.文档.视图关联在一起b)文档类(CDocument): ...

  9. 提高你的数据库编程效率:Microsoft CLR Via Sql Server

    你还在为数据库编程而抓狂吗?那些恶心的脚本拼接,低效的脚本调试的日子将会与我们越来越远啦.现在我们能用支持.NET的语言来开发数据库中的对象,如:存储过程,函数,触发器,集合函数已及复杂的类型.看到这 ...

随机推荐

  1. mvn本地部署命令行

    ---创建mvn项目 mvn archetype:generate 运行结果如下: ---调试mvn仓库 mvn archetype:generate –X 运行结果如下: ---创建依赖 mvn a ...

  2. 应用.NET控制台应用程序开发批量导入程序。

    一.最近一直在调整去年以及维护去年开发的项目,好久没有在进行个人的博客了.每天抽了一定的时间在研究一些开源的框架,Drapper 以及NHibernate以及当前比较流行的SqlSuper框架 并进行 ...

  3. Jmeter参数的AES加密使用

    在Jmeter日常实践中,大家应该都遇到过接口传参需要加密的情况.以登陆为例,用户名和密码一般都需要进行加密传输,在服务端再进行解密,这样安全系数会更高,但在使用jmeter进行接口测试的时候,怎样发 ...

  4. Selenium2+python自动化-八种元素定位(Firebug和Firepath)

    前言    自动化只要掌握四步操作:获取元素,操作元素,获取返回结果,断言(返回结果与期望结果是否一致),最后自动出测试报告.本篇主要讲如何用firefox辅助工具进行元素定位.元素定位在这四个环节中 ...

  5. Selenium+Python自动化测试学习问题总结笔记

    1.问题描述:不能导入自定义类 错误内容:This inspection detects names that should resolve but don't. Due to dynamic dis ...

  6. POJ--3279(开关问题2个不同时间写的代码)

    Fliptile Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 19730   Accepted: 7118 Descrip ...

  7. BAT面试必备——Java 集合类

    本文首发于我的个人博客:尾尾部落 1. Iterator接口 Iterator接口,这是一个用于遍历集合中元素的接口,主要包含hashNext(),next(),remove()三种方法.它的一个子接 ...

  8. flask中的if __name__ == "__main__"

    在编写python文件时,一般会在入口文件中加入if __name__ == "__main__", 这样当这个脚本文件执行时就会执行这个语句下面的内容,而如果这个脚本文件被当作模 ...

  9. vue 组件-父组件传值给子组件

    父组件通过属性,传值给子组件,子组件通过,props数组里的名称来接受父组件传过来的值. HTML部分: <div id="app"> <tmp1 :parent ...

  10. 比较语义分割的几种结构:FCN,UNET,SegNet,PSPNet和Deeplab

    简介 语义分割:给图像的每个像素点标注类别.通常认为这个类别与邻近像素类别有关,同时也和这个像素点归属的整体类别有关.利用图像分类的网络结构,可以利用不同层次的特征向量来满足判定需求.现有算法的主要区 ...