C++ 获取每一行的数据 FetchRow() 用vector()实现

1、在LXData里面定义结构体

cpp 复制代码
    struct LXAPI LXData
	{
		const char* data = 0;
		int size = 0;
	};

2、在LXMysql.h和LXMysql.cpp分别定义和编写代码

cpp 复制代码
//获取一行数据
	std::vector<LXData>FetchRow();
cpp 复制代码
std::vector<LXData> LXMysql::FetchRow()
	{
		std::vector<LXData>re;
		if (!result)
		{
			return re;
		}
		MYSQL_ROW row = mysql_fetch_row(result);
		if (!row)
		{
			return re;
		}
		//列数,每一个数据的大小
		int fnum = mysql_num_fields(result);
		unsigned long* lens = mysql_fetch_lengths(result);
		for (int i = 0;i < fnum;i++)
		{
			LXData data;
			data.data = row[i];
			data.size = lens[i];
			re.push_back(data);
		}
		return re;
	}

3、测试,在test_LXMysql.cpp里面测试

cpp 复制代码
    //4、获取结果集
    sql = "insert into t_vedio (name) values ('test0001')";
    //多插入几个数据
    cout << my.Query(sql.c_str()) << endl;
    cout << my.Query(sql.c_str()) << endl;
    cout << my.Query(sql.c_str()) << endl;
    cout << my.Query(sql.c_str()) << endl;
    sql = "select *from t_vedio";
    cout << my.Query(sql.c_str()) << endl;

    my.StoreResult();//结果集本地全部存储
    for (;;)
    {
        auto row = my.FetchRow();
        if (row.size() == 0)
        {
            /*cout << "cedw" << endl;*/
            break;
        }
        row[2].SaveFile(row[1].data);
        for (int i = 0;i < row.size();i++)
        {
            if (row[i].data)
            {
                cout << row[i].data << " ";
            }
        }
        cout << endl;
    }

    my.FreeResult();


    cout << my.Query(sql.c_str()) << endl;
    my.UseResult();//开始接收结果集
    my.FreeResult();
相关推荐
QX_hao23 分钟前
【Go】--map和struct数据类型
开发语言·后端·golang
你好,我叫C小白27 分钟前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
Evand J2 小时前
【MATLAB例程】基于USBL和DVL的线性回归误差补偿,对USBL和DVL导航数据进行相互补偿,提高定位精度,附代码下载链接
开发语言·matlab·线性回归·水下定位·usbl·dvl
TDengine (老段)2 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)2 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
@yanyu6662 小时前
idea中配置tomcat
java·mysql·tomcat
安当加密3 小时前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
Larry_Yanan3 小时前
QML学习笔记(四十二)QML的MessageDialog
c++·笔记·qt·学习·ui
爱喝白开水a3 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
想ai抽3 小时前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库