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的语言来开发数据库中的对象,如:存储过程,函数,触发器,集合函数已及复杂的类型.看到这 ...
随机推荐
- html5 初试 indexedDB
indexedDB是存储大量结构化数据的API,demo中用到的是异步API,麻烦的就是所有对indexedDB的操作都会发生一个异步的‘请求’,只要熟悉了API操作起来也很简单. http://ww ...
- x5webview 自定义全屏界面
集成X5WEBVIEW可以选择全屏模式为标准全屏还是x5全屏,而不设置默认为false. 首先看看标准全屏的基本设置, if (webView.getX5WebViewExtension() != n ...
- CentOS7上部署ASP.Net Core 2.2应用
前言 在CentOS7上部署ASP.Net Core应用是我的技术路线验证的一部分,下一个产品计划采用ASP.Net Boilerplate Framework开发.因此需要求提前进行一下技术验证,在 ...
- Docker--删除容器实例和镜像
一.删除容器实例 使用命令docker rm 容器ID或者容器名 1.docker ps -a查询已有的实例 [root@cxt data]# docker ps -a 2.docker rm 容器I ...
- JSON toBean Timestamp To Date 时间戳转日期
时间戳格式的时间从json转为date时 配置: import java.util.Date; import net.sf.ezmorph.object.AbstractObjectMorpher; ...
- c# 程序重启设定
问题情境: 程序随着时间运行,越来越大.暂时想到的两种方法,一是反攻代码,查看占内存大的函数,是不是没有回收.再就是暴力设定程序定时重启. 解决原理: 定时重启:暂设定timer,时间匹配执行rest ...
- 第二阶段每日站立会议Second Day
昨天我在手机端安装cpp后进行界面效果测试以及进一步完善 今天对图片显示的大小进行调整 遇到的问题:当图片太小时,显示一块灰色区域,不美观
- 第五次作业+4505B寝室队
1.需求分析: 作一个简单的MP3播放器,并能显示播放文件的路径. 2.设计思路: 用窗体设计播放器的界面,以市面上主流的播放器为标准,采用一个窗体的界面. 3.实现的功能: 第一是能播放MP3文件, ...
- 2018软工实践—Beta冲刺(3)
队名 火箭少男100 组长博客 林燊大哥 作业博客 Beta 冲鸭鸭鸭! 成员冲刺阶段情况 林燊(组长) 过去两天完成了哪些任务 软件接口编写修正 自动化测试脚本编写 技术文稿更新 展示GitHub当 ...
- Myeclipse2014 用Maven创建第一个web项目(1)---helloworld
一.创建项目 1.Eclipse中用Maven创建项目 2.继续Next 3.选maven-archetype-webapp后,next 4.填写相应的信息,Packaged是默认创建一个包,不写也可 ...