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()
    用于获取结果集中字段的数目,即获取一行中的列数。
    需要传递一个结果集标识符作为参数。
    返回的是结果集中当前行的列数,而不是整个结果集的列数。
相关推荐
拾贰_C2 分钟前
【mysql |centos |mysql设置】MySQL修改密码并创建用户,系统安全默认开启了密码复杂度检查组件,怎么解决
mysql·centos·系统安全
色空大师30 分钟前
【mysql建表避坑指南】
数据库·mysql
V1ncent Chen44 分钟前
从零学SQL 02 MySQL架构介绍
数据库·sql·mysql·架构·数据分析
大母猴啃编程1 小时前
MySQL内置函数
数据库·sql·mysql·adb
@atweiwei1 小时前
MySQL vs MongoDB 深度对比(底层存储数据结构与并发控制篇)
数据结构·数据库·后端·sql·mysql·mongodb·个人开发
V1ncent Chen1 小时前
从零学SQL 04 MySQL Workbench用法简介
数据库·sql·mysql·数据分析
ZZZKKKRTSAE1 小时前
在rhel9中部署MySQL
数据库·mysql
m0_547722921 小时前
乒乓球比赛管理系统
python·mysql
杨云龙UP2 小时前
Oracle与MySQL数据库运行状态快速检查指南
数据库·mysql·oracle
rrrjqy2 小时前
MySQL事务深度解析:从ACID特性到隔离级别实战
数据库·mysql·oracle