当前位置: 首页 > news >正文

C++学习之数据库操作

目录

 

1.知识点概述

2.occi中事务操作

3.数据表介绍

4.关于数据库中创建第二个用户

5.项目中秘钥协商对应的数据库操作

6.项目中数据库操作对象的添加和初始化

7.共享秘钥写入数据库

8.写数据库操作先关occi函数封装和使用

9.验证秘钥写数据功能

10.配置管理终端的作用

11.在qt中通过源码编码oci驱动

12.qt中的QSLDATABASE常用api

13.qt中数据库查询相关api函数

14.qt中链接数据代码

15.数据库查询遍历结果集

16.qt中数据库事务操作

17.qt中链接Mysql的注意事项

18.配置管理终端作用

19.QJSONDOCUMENT和QJSONARRAY类

20.json对象类

21.QJSONVALUE类

22.将json数组或对象转换为字符串步骤


 

1.知识点概述

2.occi中事务操作

3.数据表介绍

- 在Qt中进行数据库操作需要使用的类: `QSqlDataBase`

  - 属于的模块: `sql`

  - 使用这个类可以创建出一个连接数据库服务器的实例

    - 单例

  - 相关的操作函数

    ```c++
    // 打印qt支持的数据库驱动的名字
    // QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7
    [static] QStringList QSqlDatabase::drivers()
    // 添加一个数据库实例
    [static] QSqlDatabase QSqlDatabase::addDatabase(const QString &type, const QString &connectionName = QLatin1String( defaultConnection ))

4.关于数据库中创建第二个用户

    参数:
            - type: 连接什么样的数据库, 不同的数据库对应不同的type字符串
            - connectionName: 连接名, 在一个项目中连接2个及以上数据库的时候需要指定连接名
    // 得到通过addDatabase函数添加的实例对象
    [static] QSqlDatabase QSqlDatabase::database(const QString &connectionName = QLatin1String( defaultConnection ), bool open = true)
    // 关闭数据库连接
    void QSqlDatabase::close();
    
    // 初始化要连接远程数据库服务器信息
    // 设置远程数据库服务器地址
    void QSqlDatabase::setHostName(const QString &host);
        - host: 可被解析的域名, 或者是一个IP地址
    // 设置连接的服务器监听的端口
    // 这个函数可以不调用, 如果数据库的监听的默认端口没有被修改过, 就不需要进行setPort的设置
    void QSqlDatabase::setPort(int port);
    // 设置数据实例名(数据库名)
    void QSqlDatabase::setDatabaseName(const QString &name);
    // 设置数据库用户
    void QSqlDatabase::setUserName(const QString &name);
    // 设置数据库密码
    void QSqlDatabase::setPassword(const QString &password);

5.项目中秘钥协商对应的数据库操作

 // 连接数据库
    // 返回true-> 连接成功, false-> 连接失败
    bool QSqlDatabase::open();
    
    // 事务相关
    bool QSqlDatabase::transaction();
    // 提交事务
    bool QSqlDatabase::commit();
    // 数据回滚
    bool QSqlDatabase::rollback();
    ```

  - 数据库查询的类: `QSqlQuery`

    ```c++
    // 构造函数
    QSqlQuery::QSqlQuery(const QString &query = QString(), QSqlDatabase db = QSqlDatabase());
    // 执行一个sql语句, 可以在构造对象的时候指定, 也可以在exec的时候指定
    bool QSqlQuery::exec();
    bool QSqlQuery::exec(const QString &query);
    
    // 如果是查询数据库, 会得到一个结果集, 结果可以保存在 QSqlQuery 对象中
    // 遍历结果集, 一条记录一条记录的遍历
    bool QSqlQuery::next();
    // 得到每条记录中的字段值
    QVariant QSqlQuery::value(int index) const;
        - index: 字段在当前记录中的编号, 从0开始
    QVariant QSqlQuery::value(const QString &name) const;
        - name: 字段的名字
    ```

6.项目中数据库操作对象的添加和初始化

```c++
// 常用类一共有四个
QJsonDocument
QJsonArray
QJsonObject
QJsonValue

// 使用json实际场景: json数据在内存, json数据在磁盘中
// 数据在磁盘文件中
1. 读磁盘文件 -> 字符串 -> json格式
2. json格式字符串 -> json数组/对象
    - 通过QJsonDocument进行转换
3. 使用QJsonArray或QJsonObject api对数据进行操作
```
 

7.共享秘钥写入数据库

```c++
// json格式字符串 -> json文档对象
[static] QJsonDocument QJsonDocument::fromJson(const QByteArray &json, QJsonParseError *error = Q_NULLPTR);
// 判断文档对象中存储的是数组还是对象
bool QJsonDocument::isArray() const;
bool QJsonDocument::isObject() const;
// 文档对象转换为数组
QJsonArray QJsonDocument::array() const;
// 文档对象转换为jsonobject
QJsonObject QJsonDocument::object() const;
```

8.写数据库操作先关occi函数封装和使用

```c++
// 在内存中组织一个json数组/json对象 -> 写文件/发送
1. 创建json数组/json对象 (空数组/对象)
2. 添加数据
    - jsonarray: append, insert
    - jsonobject: insert
3. 将jsonarray, jsonobject -> QJsonDocument对象
    QJsonDocument::QJsonDocument(const QJsonObject &object);
    QJsonDocument::QJsonDocument(const QJsonArray &array);
4. QJsonDocument对象中的数据 -> 字符串
    QByteArray QJsonDocument::toJson(JsonFormat format = Indented) const;
5. 比如要写磁盘
    QFile
```

9.验证秘钥写数据功能

在Qt中进行数据库操作需要使用的类: QSqlDataBase

  • 属于的模块: sql

  • 使用这个类可以创建出一个连接数据库服务器的实例

  • 单例

  • 相关的操作函数

```c++ // 打印qt支持的数据库驱动的名字 // QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7 [static] QStringList QSqlDatabase::drivers() // 添加一个数据库实例 [static] QSqlDatabase QSqlDatabase::addDatabase(const QString &type, const QString &connectionName = QLatin1String( defaultConnection )) 参数: - type: 连接什么样的数据库, 不同的数据库对应不同的type字符串 - connectionName: 连接名, 在一个项目中连接2个及以上数据库的时候需要指定连接名 // 得到通过addDatabase函数添加的实例对象 [static] QSqlDatabase QSqlDatabase::database(const QString &connectionName = QLatin1String( defaultConnection ), bool open = true) // 关闭数据库连接 void QSqlDatabase::close();

10.配置管理终端的作用

在Qt中进行数据库操作需要使用的类: QSqlDataBase

  • 属于的模块: sql

  • 使用这个类可以创建出一个连接数据库服务器的实例

  • 单例

  • 相关的操作函数

```c++ // 打印qt支持的数据库驱动的名字 // QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7 [static] QStringList QSqlDatabase::drivers() // 添加一个数据库实例 [static] QSqlDatabase QSqlDatabase::addDatabase(const QString &type, const QString &connectionName = QLatin1String( defaultConnection )) 参数: - type: 连接什么样的数据库, 不同的数据库对应不同的type字符串 - connectionName: 连接名, 在一个项目中连接2个及以上数据库的时候需要指定连接名 // 得到通过addDatabase函数添加的实例对象 [static] QSqlDatabase QSqlDatabase::database(const QString &connectionName = QLatin1String( defaultConnection ), bool open = true) // 关闭数据库连接 void QSqlDatabase::close();

11.在qt中通过源码编码oci驱动

在Qt中进行数据库操作需要使用的类: QSqlDataBase

  • 属于的模块: sql

  • 使用这个类可以创建出一个连接数据库服务器的实例

  • 单例

  • 相关的操作函数

```c++ // 打印qt支持的数据库驱动的名字 // QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7 [static] QStringList QSqlDatabase::drivers() // 添加一个数据库实例 [static] QSqlDatabase QSqlDatabase::addDatabase(const QString &type, const QString &connectionName = QLatin1String( defaultConnection )) 参数: - type: 连接什么样的数据库, 不同的数据库对应不同的type字符串 - connectionName: 连接名, 在一个项目中连接2个及以上数据库的时候需要指定连接名 // 得到通过addDatabase函数添加的实例对象 [static] QSqlDatabase QSqlDatabase::database(const QString &connectionName = QLatin1String( defaultConnection ), bool open = true) // 关闭数据库连接 void QSqlDatabase::close();

12.qt中的QSLDATABASE常用api

 

13.qt中数据库查询相关api函数

 

14.qt中链接数据代码

 

15.数据库查询遍历结果集

 

 

16.qt中数据库事务操作

 

17.qt中链接Mysql的注意事项

 

18.配置管理终端作用

 

19.QJSONDOCUMENT和QJSONARRAY类

 

20.json对象类

 

21.QJSONVALUE类

 

22.将json数组或对象转换为字符串步骤

 

 

相关文章:

  • AI日报 - 2025年4月15日
  • 华为OD机试真题——阿里巴巴找黄金宝箱 IV(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
  • 子串-滑动窗口的最大值
  • 科研软件分享
  • AI agents系列之全从零开始构建
  • 批处理(Batch Processing)的详解、流程及框架/工具的详细对比
  • 前端工程化之自动化构建
  • .NET MCP 文档
  • 多模态思维链(Multimodal Chain of Thought, MCoT)六大技术支柱在医疗领域的应用
  • OpenCv--换脸
  • 群辉搭建静态网站
  • 基于 Qt 的 BMP 图像数据存取至 SQLite 数据库的实现
  • WSL2 配置和离线安装linux系统。
  • 基础算法篇(5)(蓝桥杯常考点)—动态规划(C/C++)
  • PyCharm 开发工具 修改字体大小及使用滚轮没有反应
  • 【Wasserstein-1 距离】
  • Spring Boot + ShardingSphere 分库分表实战:电商订单场景案例
  • cline 提示词工程指南-架构篇
  • 美团即时零售大动作,将独立的闪购将会改变什么?
  • UE5 设置父物体和解除父子关系(移除子物体)
  • 马上评丨机械停车库成“僵尸库”,设计不能闭门造车
  • 视觉周刊|2025上海车展的科技范
  • 李在明当选韩国共同民主党总统候选人
  • 榆林市委常委王华胜已任榆林市政协党组书记
  • 全球首台环形CT直线加速器在沪正式开机,系我国自主研发
  • 涉李小龙形象商标被判定无效,真功夫:暂无更换计划