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的语言来开发数据库中的对象,如:存储过程,函数,触发器,集合函数已及复杂的类型.看到这 ...
随机推荐
- mvn本地部署命令行
---创建mvn项目 mvn archetype:generate 运行结果如下: ---调试mvn仓库 mvn archetype:generate –X 运行结果如下: ---创建依赖 mvn a ...
- 应用.NET控制台应用程序开发批量导入程序。
一.最近一直在调整去年以及维护去年开发的项目,好久没有在进行个人的博客了.每天抽了一定的时间在研究一些开源的框架,Drapper 以及NHibernate以及当前比较流行的SqlSuper框架 并进行 ...
- Jmeter参数的AES加密使用
在Jmeter日常实践中,大家应该都遇到过接口传参需要加密的情况.以登陆为例,用户名和密码一般都需要进行加密传输,在服务端再进行解密,这样安全系数会更高,但在使用jmeter进行接口测试的时候,怎样发 ...
- Selenium2+python自动化-八种元素定位(Firebug和Firepath)
前言 自动化只要掌握四步操作:获取元素,操作元素,获取返回结果,断言(返回结果与期望结果是否一致),最后自动出测试报告.本篇主要讲如何用firefox辅助工具进行元素定位.元素定位在这四个环节中 ...
- Selenium+Python自动化测试学习问题总结笔记
1.问题描述:不能导入自定义类 错误内容:This inspection detects names that should resolve but don't. Due to dynamic dis ...
- POJ--3279(开关问题2个不同时间写的代码)
Fliptile Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 19730 Accepted: 7118 Descrip ...
- BAT面试必备——Java 集合类
本文首发于我的个人博客:尾尾部落 1. Iterator接口 Iterator接口,这是一个用于遍历集合中元素的接口,主要包含hashNext(),next(),remove()三种方法.它的一个子接 ...
- flask中的if __name__ == "__main__"
在编写python文件时,一般会在入口文件中加入if __name__ == "__main__", 这样当这个脚本文件执行时就会执行这个语句下面的内容,而如果这个脚本文件被当作模 ...
- vue 组件-父组件传值给子组件
父组件通过属性,传值给子组件,子组件通过,props数组里的名称来接受父组件传过来的值. HTML部分: <div id="app"> <tmp1 :parent ...
- 比较语义分割的几种结构:FCN,UNET,SegNet,PSPNet和Deeplab
简介 语义分割:给图像的每个像素点标注类别.通常认为这个类别与邻近像素类别有关,同时也和这个像素点归属的整体类别有关.利用图像分类的网络结构,可以利用不同层次的特征向量来满足判定需求.现有算法的主要区 ...