Qt——数据库编程
一、概述
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——数据库编程的更多相关文章
- Qt数据库编程1
Qt中数据编程主要分为以下两点:1.利用qt提供类 访问数据库或者成为简单的数据库编程2.数据库编程中引入model/view编程模型 qt中数据库编程的步骤: 1.加载数据库驱动 QSqlDatab ...
- QT 数据库编程三
//mainwindow.cpp #include "mainwindow.h" #include "logindlg.h" #include "sc ...
- Qt数据库编程_基本
QtSql模块提供了一个平台无关且数据库无关的访问SQL数据库的接口. Qt中的每个数据库连接用一个QSqlDatabase对象来表示:Qt使用不同driver来和各种不同数据库的API进行通讯. Q ...
- QT 数据库编程四
//vmysql.cpp #include "vmysql.h" #include <QMessageBox> Vmysql::Vmysql() { mysql_ini ...
- QT 数据库编程二
//logindlg.cpp #include "logindlg.h" #include <QGridLayout> #include <QHBoxLayout ...
- QT基于model/view数据库编程2
Qt中数据编程主要分为以下两点:1.利用qt提供类 访问数据库或者成为简单的数据库编程2.数据库编程中引入model/view编程模型 基于model/view数据库编程: qt提供model类: Q ...
- c++学习书籍推荐《C++ GUI Qt 4编程(第2版)》下载
下载地址:点我 百度云及其他网盘下载地址:点我 编辑推荐 <C++ GUI Qt 4编程(第2版)>讲授的大量Qt4编程原理和实践,都可以轻易将其应用于Qt4.4.Qt4.5及后续版本的Q ...
- (九)文档和视图,Invalidate,数据库编程
一.文档视图结构 文档类(CDocument):存储加载(读写)数据视图类(CView):显示和修改数据 1)单文档 a)文档模板:把框架窗口.文档.视图关联在一起b)文档类(CDocument): ...
- 提高你的数据库编程效率:Microsoft CLR Via Sql Server
你还在为数据库编程而抓狂吗?那些恶心的脚本拼接,低效的脚本调试的日子将会与我们越来越远啦.现在我们能用支持.NET的语言来开发数据库中的对象,如:存储过程,函数,触发器,集合函数已及复杂的类型.看到这 ...
随机推荐
- Linux中的mysql指令
如何启动/停止/重启MySQL一.启动方式1.使用 service 启动:service mysqld start2.使用 mysqld 脚本启动:/etc/inint.d/mysqld start3 ...
- android安卓生成密钥keystore(命令控制)
android安卓生成密钥keystore(命令控制) • 配置JDK 详细教程 https://blog.csdn.net/u012934325/article/details/73441617/ ...
- 什么是REST,RESTful?
转载自https://www.zhihu.com/question/28557115 https://blog.csdn.net/hjc1984117/article/details/77334616 ...
- 人脸识别-关于face_recognition库的安装
首先十分感谢博客https://blog.csdn.net/scc_722/article/details/80613933,经历过很多尝试(快要醉了),终于看了这篇博客后安装成功. face_rec ...
- jQuery的$ .ajax防止重复提交的方法
没啥说的直接贴代码,很简单: 第一种方式:的onclick点击事件类型 <SCRIPT> function member_del(obj,id){ var lock = false; // ...
- Vuex 单状态库 与 多模块状态库
之前对 Vuex 进行了简单的了解.近期在做 Vue 项目的同时重新学习了 Vuex .本篇博文主要总结一下 Vuex 单状态库和多模块 modules 的两类使用场景. 本篇所有代码是基于 Vue- ...
- Linux系列——安装双系统Ubuntu
作为一个穷人,电脑破得不行却没钱换,怎么办呢,不如换个Ubuntu吧,没有Windows那么多后台应用,在我这台古董上稍微流畅一点. Linux有很多发行版,比较流行和适合入门的就是Ubuntu和De ...
- ossec安装
安装 安装要求 对于Unix系统来说,OSSEC只需要GNU的make.gcc和libc.推荐使用OpenSSL,但仅属于一个可选项.而且,通常您只需在一个系统上做编译操作,然后将二进制程序复制到其他 ...
- ubuntu下修改nginx的进程数
1. 进入nginx配置文件:vim /etc/nginx/nginx.conf2. 将events下的worker_processes 修改为 你希望的数字,保存文件并退出3. 重启nginx: s ...
- [linux] LVM磁盘管理(针对xfs和ext4不同文件系统)
简单来说就是:PV:是物理的磁盘分区VG:LVM中的物理的磁盘分区,也就是PV,必须加入VG,可以将VG理解为一个仓库或者是几个大的硬盘LV:也就是从VG中划分的逻辑分区如下图所示PV.VG.LV三者 ...