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()
    用于获取结果集中字段的数目,即获取一行中的列数。
    需要传递一个结果集标识符作为参数。
    返回的是结果集中当前行的列数,而不是整个结果集的列数。
相关推荐
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.34 分钟前
MySQL高可用集群实战:MHA搭建全攻略
android·mysql·adb
毅炼38 分钟前
MySQL 常见问题总结(3)
数据库·sql·mysql
杨云龙UP1 小时前
ODA-Oracle实践记录:通过Navicat导出导入表CSV文件并清理重复数据,处理OA待办延迟刷新问题_20260416
linux·运维·服务器·数据库·sql·mysql·oracle
xuhaoyu_cpp_java1 小时前
MySql学习(四)
数据库·经验分享·笔记·sql·学习·mysql
suliqiang1 小时前
MySQL数据库性能优化实战:系统性能提升100%的完整指南
数据库·mysql·性能优化
快点好好学习吧2 小时前
CPU 从 L1/L2 缓存读取 MySQL 代码指令的庖丁解牛
android·mysql·缓存
武超杰3 小时前
MySQL调优(三)——EXPLAIN 执行计划
数据库·mysql
梦想与想象-广州大智汇4 小时前
告别“内存刺客”!sync-canal-go:轻量mysql实时同步数据到Elasticsearch‌,clickhouse,redis
mysql·elasticsearch·golang·同步数据
小菜同学爱学习4 小时前
进阶实操!MySQL常用查询技巧(多场景案例+优化思路)
数据库·mysql
考虑考虑4 小时前
SQL语句中的模糊查询注意
后端·sql·mysql