一、概述

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. Linux中的mysql指令

    如何启动/停止/重启MySQL一.启动方式1.使用 service 启动:service mysqld start2.使用 mysqld 脚本启动:/etc/inint.d/mysqld start3 ...

  2. android安卓生成密钥keystore(命令控制)

    android安卓生成密钥keystore(命令控制) • 配置JDK 详细教程 https://blog.csdn.net/u012934325/article/details/73441617/ ...

  3. 什么是REST,RESTful?

    转载自https://www.zhihu.com/question/28557115 https://blog.csdn.net/hjc1984117/article/details/77334616 ...

  4. 人脸识别-关于face_recognition库的安装

    首先十分感谢博客https://blog.csdn.net/scc_722/article/details/80613933,经历过很多尝试(快要醉了),终于看了这篇博客后安装成功. face_rec ...

  5. jQuery的$ .ajax防止重复提交的方法

    没啥说的直接贴代码,很简单: 第一种方式:的onclick点击事件类型 <SCRIPT> function member_del(obj,id){ var lock = false; // ...

  6. Vuex 单状态库 与 多模块状态库

    之前对 Vuex 进行了简单的了解.近期在做 Vue 项目的同时重新学习了 Vuex .本篇博文主要总结一下 Vuex 单状态库和多模块 modules 的两类使用场景. 本篇所有代码是基于 Vue- ...

  7. Linux系列——安装双系统Ubuntu

    作为一个穷人,电脑破得不行却没钱换,怎么办呢,不如换个Ubuntu吧,没有Windows那么多后台应用,在我这台古董上稍微流畅一点. Linux有很多发行版,比较流行和适合入门的就是Ubuntu和De ...

  8. ossec安装

    安装 安装要求 对于Unix系统来说,OSSEC只需要GNU的make.gcc和libc.推荐使用OpenSSL,但仅属于一个可选项.而且,通常您只需在一个系统上做编译操作,然后将二进制程序复制到其他 ...

  9. ubuntu下修改nginx的进程数

    1. 进入nginx配置文件:vim /etc/nginx/nginx.conf2. 将events下的worker_processes 修改为 你希望的数字,保存文件并退出3. 重启nginx: s ...

  10. [linux] LVM磁盘管理(针对xfs和ext4不同文件系统)

    简单来说就是:PV:是物理的磁盘分区VG:LVM中的物理的磁盘分区,也就是PV,必须加入VG,可以将VG理解为一个仓库或者是几个大的硬盘LV:也就是从VG中划分的逻辑分区如下图所示PV.VG.LV三者 ...