我们正在进行一项任务。
我们目前正在尝试在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标志也为连接启用。我们已经查看了其他几个类似的问题,但我们似乎已启用标记并且调用顺序正确。
答案 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,选择2类型语句。
if(temp = mysql_stmt_store_result(stmt))
mysql_stmt_store_result不会返回MYSQL_RES。可能temp是null