C MySQL连接器 - 错误2014 - 使用CALL时命令不同步

时间:2015-03-23 21:25:41

标签: mysql c stored-procedures

我们正在进行一项任务。 我们目前正在尝试在MySQL数据库中调用远程过程,但是我们得到了2014年的错误,我们无法弄清楚原因。我们应该注意到调用是成功的,我们得到了我们期望获得的结果,问题在于调用mysql_stmt_close(stmt)。 我们使用mysql_free_result释放由连接器调用生成的每个MYSQL结构,但错误仍然存​​在。该错误来自mysql_stmt_close(stmt)来电,我们收到了2014年的错误,如标题中所述。就我们所见,我们正在释放每一个MYSQL结构。

代码主要来自互联网上的示例:

int basedatos_crearUsuario(char * pNombre, MYSQL * pConeccion){
char * query = "CALL crearUsuario (?)";
MYSQL_STMT *stmt;
MYSQL_BIND ps_params[1];  /* input parameter buffers */
MYSQL_BIND bind_results[1];

stmt = mysql_stmt_init(pConeccion);
if (!stmt)
{
    printf("Could not initialize statement\n");
    return -1;
}
if (mysql_stmt_prepare(stmt, query, strlen(query))){
    fprintf(stderr, "Error: %s (errno: %d)\n",mysql_error(pConeccion), mysql_errno(pConeccion));
    return -1;
}

long largo = (long) strlen(pNombre);
memset(ps_params, 0, sizeof (ps_params));
ps_params[0].buffer_type = MYSQL_TYPE_STRING;
ps_params[0].buffer = pNombre;
ps_params[0].buffer_length = largo;
ps_params[0].length = &largo;
ps_params[0].is_null = 0;

if(mysql_stmt_bind_param(stmt, ps_params)){
    fprintf(stderr, "Error: %s (errno: %d)\n",mysql_error(pConeccion), mysql_errno(pConeccion));
    return -1;
}
if (mysql_stmt_execute(stmt)){
    fprintf(stderr, "Error: %s (errno: %d)\n",mysql_error(pConeccion), mysql_errno(pConeccion));
    return -1;
}
MYSQL_RES* temp;
if (temp = mysql_stmt_store_result(stmt)) { //
    fprintf(stderr, " mysql_stmt_execute(), 1 failed\n");
    fprintf(stderr, " %s\n", mysql_stmt_error(stmt));
    return -1;
}
MYSQL_RES* aRes = mysql_stmt_result_metadata(stmt);//

MYSQL_FIELD* aField = &(aRes->fields[0]); 
int totalrows = mysql_stmt_num_rows(stmt);

int resultadoQuery;
long largo2 = 0;
memset (bind_results, 0, sizeof (bind_results));
bind_results[0].buffer_type= aField->type;
bind_results[0].is_null= 0;
bind_results[0].buffer= (char *) &resultadoQuery;
bind_results[0].buffer_length= 255;
bind_results[0].length= &largo2;

mysql_stmt_bind_result(stmt, bind_results);  
while(!mysql_stmt_fetch(stmt)){
    printf("hay result");
}

mysql_free_result(aRes);
mysql_free_result(temp);
if (mysql_stmt_close(stmt)) //HERE: the stmt_close call returns an error.
{
  fprintf(stderr, " usuario failed while closing the statement\n");
  fprintf(stderr, " %s\n", mysql_stmt_error(stmt));
  exit(0);
}

return resultadoQuery;

我们希望了解为何会发生这种情况。 CLIENT_MULTI_RESULTS标志也为连接启用。我们已经查看了其他几个类似的问题,但我们似乎已启用标记并且调用顺序正确。

2 个答案:

答案 0 :(得分:3)

请参阅以下文档: https://dev.mysql.com/doc/refman/5.6/en/mysql-store-result.html https://dev.mysql.com/doc/refman/5.6/en/c-api-multiple-queries.html https://dev.mysql.com/doc/refman/5.6/en/mysql-next-result.html(可能是最有用的链接)

您的CALL语句很可能返回多个结果集,通常如果您运行一个SELECT,该过程返回过程中的数据,那么您将获得一个查询结果集,然后是过程执行本身的第二个结果集。

您需要前进到该过程的下一个结果集,并对其进行处理(或将其丢弃)。

我会在mysql_next_result上循环,然后在mysql_free_result之后和mysql_stmt_close之前抛弃它们。

答案 1 :(得分:1)

尝试调试存储过程

  1. 检查存储过程中是否存在返回多行的select语句
  2. 检查您的存储过程中是否存在您忘记删除的日志语句,即。标准输出或选择1,选择2类型语句。

    if(temp = mysql_stmt_store_result(stmt))

  3. mysql_stmt_store_result不会返回MYSQL_RES。可能temp是null