关于一个mysql_field_count的有关问题

  • 内容
  • 评论
  • 相关

关于一个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*)

欢迎大家阅读《关于一个mysql_field_count的有关问题》,跪求各位点评,by 搞代码

原创文章,转载请注明: 转载自搞代码

本文链接地址: 关于一个mysql_field_count的有关问题

微信支付二维码

微信 赏一包辣条吧~

支付宝支付二维码

支付宝 赏一听可乐吧~

评论

0条评论

发表评论

电子邮件地址不会被公开。 必填项已用*标注