2014 Commands out of sync; you can't run this command now


错误简介

在使用mysql_query进行查询操作时,报错如下:

2014 Commands out of sync; you can't run this command now

错误原因

第一次调用mysql_query/mysql_real_query之后,没有进行mysql_store_result操作,导致的此错误。

如下代码可以复现:

#include <mysql/mysql.h>
#include <iostream>
#include <unistd.h>
using namespace std;

int main()
{
    MYSQL* conn;
    MYSQL_RES* res;
    MYSQL_ROW row;
    char* query="select * from ashe where id>3";

    conn=mysql_init(0);
    if(!mysql_real_connect(conn,"192.168.30.129","ashe","ashe","ashe",13307,NULL,0))
    {
        cout << mysql_errno(conn) << " " << mysql_error(conn) <<endl;
        return -1;
    }

    int i=0;
    while(i<1000000)
    {
        cout << i <<endl;
        if(mysql_query(conn,query))
        {
            cout << mysql_errno(conn) << " " << mysql_error(conn)  << endl;
            return -1;
        }
        else
        {
//            res=mysql_store_result(conn);
//            while(row=mysql_fetch_row(res))
//            {
//                cout << row[0] <<endl;
//                cout << row[1] <<endl;
//            }
//            mysql_free_result(res);
//            mysql_free_result(res);
        }
        i++;
    }

}

解决方案

在每一次query之后,都进行一次store操作。

如上所说的方法只能解决如题所示的问题,但是也会造成内存泄漏,因为每一次执行mysql_store_result都会重新分配新的内存,并没有执行mysql_free_result进行内存释放。所以需要在执行mysql_store_result之后,需要进行一次释放操作。

但是,如果执行两次mysql_free_result,又会引发段错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值