MySQL cAPI踩下的坑

1.使用mysql_real_query函数查询之后没有对结果集进行释放

MySQL中,如果查询之后没有释放结果集,会导致MySQL无法进行下一步操作

使用mysql_errno获取错误码:2014

正确做法

c 复制代码
//执行查询
mysql_real_query(mysql_, stmt_str.c_str(), length);
//获取结果集
MYSQL_RES *res = mysql_store_result(mysql_);
// 释放结果集以便下一步的mysql插入操作
mysql_free_result(res);

2.mysql_field_count 和 mysql_num_fields 是两个不同的 MySQL 函数

  • mysql_field_count()
    用于获取上一条与指定连接标识符关联的查询所取得的列数。
    返回的是整个查询结果集的列数,而不是特定的行的列数。
    通常用于检查查询返回的列数是否符合预期。
  • mysql_num_fields()
    用于获取结果集中字段的数目,即获取一行中的列数。
    需要传递一个结果集标识符作为参数。
    返回的是结果集中当前行的列数,而不是整个结果集的列数。
相关推荐
齐 飞20 分钟前
数据库批量插入耗时过长问题rewriteBatchedStatements=true
数据库·mysql
sg_knight20 分钟前
SQL 中的 IFNULL 函数是什么?
数据库·sql·mysql·oracle·database·关系型数据库·db
一码归一码@2 小时前
Mysql进阶之事务原理
数据库·mysql
东城绝神10 小时前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》
linux·运维·mysql·架构·高可用·ndb cluster
衫水12 小时前
[特殊字符] MySQL 常用指令大全
数据库·mysql·oracle
阿杰 AJie14 小时前
MySQL 里给表添加索引
数据库·mysql
林鸿群16 小时前
ubuntu 26.04 安装mysql-server
linux·mysql·ubuntu
_F_y16 小时前
MySQL表的操作
android·数据库·mysql
千寻技术帮17 小时前
10336_基于SSM的少数民族文化商城
mysql·毕业设计·ssm·非遗商城
fenglllle17 小时前
MySQL explain format的差异
数据库·mysql