日期:2014-05-16  浏览次数:20751 次

关于一个mysql_field_count的问题
我用的是mysql
不知道为什么n=mysql_field_count(&mysql)返回的n值一直是1。
下面是那一段代码(前面的connect和query都是没有问题的)
 res=mysql_use_result(&mysql);

  n=mysql_field_count(&mysql);
  //n=100;
  printf("n=%d\n",n);
  for(r=0;r<n;r++){
  row=mysql_fetch_row(res);
  lengths=mysql_fetch_lengths(res);
  if(row<0) {printf("break\n"); break;}
  for(t=0;t<mysql_num_fields(res);t++){
  printf("%s ",row[t]);
  }
  printf("\n");
  }
这样子显示的结果只有查询的第一条。
如果是将这一行 n=mysql_field_count(&mysql);去掉,而直接用下面的一行n=100;来给n赋值,可以显示100条查询结果。
我现在就是要得到查询到结果的记录条数,请高手帮忙。我看书上也是用mysql_field_count()来查询的,为什我这里不行??

------解决方案--------------------
没细看你的代码,下面是手册中的例子。

C/C++ code
MYSQL_RES *result;
unsigned int num_fields;
unsigned int num_rows;

if (mysql_query(&mysql,query_string))
{
    // error
}
else // query succeeded, process any data returned by it
{
    result = mysql_store_result(&mysql);
    if (result)  // there are rows
    {
        num_fields = mysql_num_fields(result);
        // retrieve rows, then call mysql_free_result(result)
    }
    else  // mysql_store_result() returned nothing; should it have?
    {
        if(mysql_field_count(&mysql) == 0)
        {
            // query does not return data
            // (it was not a SELECT)
            num_rows = mysql_affected_rows(&mysql);
        }
        else // mysql_store_result() should have returned data
        {
            fprintf(stderr, "Error: %s\n", mysql_error(&mysql));
        }
    }
}

------解决方案--------------------
用这个获取结果集的行数
mysql_num_rows(MYSQL_RES*)