vs c++ 查询mysql 获取返回集数据转化

返回集数据结构[ 指针数组1 -> ["值1", "值2", "值3", ...], 指针数组2 -> ["值1", "值2", "值3", ...], ... ]

改为

指针 -> [ {"字段1": "值1", "字段2": "值2", ...}, {"字段1": "值1", "字段2": "值2", ...}, ... ]

+----------------+     +----------------+     +----------------+
| 指针数组1      |     | 指针数组2      |     | ...            |
| -> ["值1", "值2", ...]| -> ["值1", "值2", ...]|                |
+----------------+     +----------------+     +----------------+
转换后的数据结构示意图:


+----------------+
| 指针           |
| -> [           |
|      {"字段1": "值1", "字段2": "值2", ...}, |
|      {"字段1": "值1", "字段2": "值2", ...}, |
|      ...                                  |
|    ]                                     |
+----------------+
在上述示意图中,原始数据是由多个指针数组组成,每个数组对应结果集中的一行。转换后,我们有一个指针,它指向一个包含多个字典的数组,每个字典包含了字段名和对应的值。

​​​​​​​

cpp 复制代码
vector<map<string, string>> result; // [{ "id": "3","name": "Michael","age" : "35"},{},{},...]

// 执行查询
/*
    1 查询  mysql_query 只返回成功失败 ->数据保存到内存
    2 获取结果指针 mysql_store_result
    3 处理数据
*/
if (mysql_query(con, sql.c_str()) == 0) { // 该函数用于执行SQL查询语句,其中con是数据库连接对象,sql.c_str()将sql字符串转换为C风格的字符串。如果执行成功,返回值为0
    MYSQL_RES* result_set = mysql_store_result(con); // 该函数用于获取查询结果集,返回一个指向结果集的指针result_set [  ["1", "John", "25"],["2", "Alice", "30"] , ["3", "Michael", "35"]]
    if (result_set != NULL) {
        int num_fields = mysql_num_fields(result_set); // 该函数用于获取结果集中的字段数。列数
        MYSQL_ROW row; // [指针1,指针2,指针3]  MYSQL_ROW是MySQL C API中定义的数据类型,用于表示结果集中的一行数据。它实际上是一个字符指针数组,每个元素都指向一列数据的字符串值

        MYSQL_FIELD* fields = mysql_fetch_fields(result_set); // 获取所有字段信息

        while ((row = mysql_fetch_row(result_set)) != NULL) { // 该函数用于逐行获取结果集中的数据,返回一个指向当前行数据的指针row。当没有更多行可获取时,返回NULL。
            map<string, string> row_data; // 定义了一个空的map对象
            for (int i = 0; i < num_fields; i++) { // 取一行 每一列的取值
                row_data[fields[i].name] = row[i]; // row_data['id'] = row[0] row_data['获取字段名'] = 获取值 的意思是将获取到的值存储到 row_data 这个 map 对象中,以字段名作为键,值作为对应的值mysql_fetch_field_direct(result_set, i)->name
            }
            result.push_back(row_data); //  是向 vector 的尾部添加一个元素的函数
        }
        // 将每个字段的指针形式改为一个指向整体字典的指针
        mysql_free_result(result_set); // 整个过程就是把数据从[[],[],[],,,] 变成[{},{},{},,,] 变为把第一个内存清空 新的数据结构存在新的内存中 将数据从 vector<vector<string>> 的结构转换为 vector<map<string, string>> 的结构
    }
}
else {
    cout << "查询失败: " << mysql_error(con) << endl;
}
相关推荐
Charles Ray19 分钟前
C++学习笔记 —— 内存分配 new
c++·笔记·学习
重生之我在20年代敲代码20 分钟前
strncpy函数的使用和模拟实现
c语言·开发语言·c++·经验分享·笔记
Dingdangr3 小时前
Android中的Intent的作用
android
技术无疆3 小时前
快速开发与维护:探索 AndroidAnnotations
android·java·android studio·android-studio·androidx·代码注入
GEEKVIP3 小时前
Android 恢复挑战和解决方案:如何从 Android 设备恢复删除的文件
android·笔记·安全·macos·智能手机·电脑·笔记本电脑
这孩子叫逆6 小时前
6. 什么是MySQL的事务?如何在Java中使用Connection接口管理事务?
数据库·mysql
迷迭所归处6 小时前
C++ —— 关于vector
开发语言·c++·算法
CV工程师小林6 小时前
【算法】BFS 系列之边权为 1 的最短路问题
数据结构·c++·算法·leetcode·宽度优先
white__ice7 小时前
2024.9.19
c++
天玑y7 小时前
算法设计与分析(背包问题
c++·经验分享·笔记·学习·算法·leetcode·蓝桥杯