SQLite3(3):Qt中使用SQLite3

目录

一、前言

二、Qt相关类

[2.1 QSqlDatabase](#2.1 QSqlDatabase)

[2.2 QSqlQuery](#2.2 QSqlQuery)

[2.3 QSqlQueryModel](#2.3 QSqlQueryModel)

三、Qt基本应用实现

[3.1 mainwindow.h](#3.1 mainwindow.h)

[3.2 mainwindow.cpp](#3.2 mainwindow.cpp)

[3.3 应用界面](#3.3 应用界面)

四、总结


一、前言

本文进行在Qt中实现SQLite3的基本功能实现演示。

在Qt中不论我们连接的何种类型的关系型数据库,在我们使用的时候其操作流程是一致的:

  • 创建数据库实例并初始化
  • 连接数据库
  • 对数据库进行一系列的添、删、查、改操作(编写并执行SQL语句)
  • 关闭数据库

系统版本:Ubuntu 22.04

IDE:QtCreator 13.0.2 (based on Qt 6.6.3)

编译器版本:Qt 6.5.3 GCC 64bit

二、Qt相关类

Qt中和数据库操作最为紧密相关的类有三个

2.1 QSqlDatabase

QSqlDatabase, 通过这个类可以实现数据库的添加、删除、复制、关闭等操作。

通过QtCreator可以查询需要增加的头文件、以及pro文件增加的内容。

代码示例:

cpp 复制代码
/*连接SQLite数据库*/
//创建数据库实例(加载对应的驱动), 加载的共享库位于/opt/Qt5.12.0/5.12.0/gcc_64/plugins/sqldrivers/
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
//设置要使用的数据库名称
db.setDatabaseName("customdb");
//连接数据库
bool ok = db.open();

注意: 使用Qt数据库模块需要在工程文件中添加 "QT += sql"。

2.2 QSqlQuery

QSqlQuery,数据库操作类,进行数据库的增、删、改、查等操作。

代码示例:

cpp 复制代码
/*查询*/
QSqlQuery query("SELECT * FROM artist");
int fieldNo = query.record().indexOf("country");
while (query.next()) {
    QString country = query.value(fieldNo).toString();
    doSomething(country);
}
/*插入*/
QSqlQuery query;
query.prepare("INSERT INTO person (id, forename, surname) "
              "VALUES (:id, :forename, :surname)");
query.bindValue(":id", 1001);
query.bindValue(":forename", "Bart");
query.bindValue(":surname", "Simpson");
query.exec();

/*也可以自行拼接字符串*/
QSqlQuery query;
query.exec("INSERT INTO employee (id, name, salary) "
            "VALUES (1001, 'Thad Beaumont', 65000)");

2.3 QSqlQueryModel

QSqlQueryModel, 执行SQL语句和遍历结果集的高级接口。它构建在底层QSqlQuery之上,可以用来为视图类(如QTableView)提供数据。

代码示例:

cpp 复制代码
QSqlQueryModel *model = new QSqlQueryModel;
model->setQuery("SELECT name, salary FROM employee");


QTableView *view = new QTableView;
view->setModel(model);
view->show();

三、Qt基本应用实现

3.1 mainwindow.h

cpp 复制代码
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QtSql/QSqlDatabase>
#include <QtSql/QSqlQuery>
#include <QtSql/QSqlQueryModel>

QT_BEGIN_NAMESPACE
namespace Ui {
class MainWindow;
}
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
    QSqlDatabase db;
    QSqlQueryModel model;
};
#endif // MAINWINDOW_H

3.2 mainwindow.cpp

cpp 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QTableView>
#include <QVBoxLayout>

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    /**/
    db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("./test.db");
    db.open();

    QSqlQuery query("SELECT * FROM COMPANY;");

    model.setQuery(query);
    QTableView *view = new QTableView(this);
    view->setModel(&model);

    QVBoxLayout* vb = new QVBoxLayout(this);
    vb->addWidget(view);
    ui->centralwidget->setLayout(vb);
}

MainWindow::~MainWindow()
{
    delete ui;
}

3.3 应用界面

四、总结

本文介绍了Qt数据库相关类,并总结了Qt操作数据库的基本操作流程,最后进行了基本应用的代码实验。

相关推荐
Bruce小鬼13 分钟前
QT文件基本操作
开发语言·qt
JH307320 分钟前
Oracle与MySQL中CONCAT()函数的使用差异
数据库·mysql·oracle
蓝染-惣右介21 分钟前
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
java·数据库·tomcat·mybatis
冷心笑看丽美人23 分钟前
Spring框架特性及包下载(Java EE 学习笔记04)
数据库
懷淰メ35 分钟前
PyQt飞机大战游戏(附下载地址)
开发语言·python·qt·游戏·pyqt·游戏开发·pyqt5
武子康1 小时前
Java-07 深入浅出 MyBatis - 一对多模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据库·sql·mybatis·springboot
代码吐槽菌2 小时前
基于SSM的毕业论文管理系统【附源码】
java·开发语言·数据库·后端·ssm
路有瑶台2 小时前
MySQL数据库学习(持续更新ing)
数据库·学习·mysql
数字扫地僧2 小时前
WebLogic 版本升级的注意事项与流程
数据库
Viktor_Ye3 小时前
高效集成易快报与金蝶应付单的方案
java·前端·数据库