• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

关于一个mysql_field_count的有关问题

mysql 搞代码 7年前 (2018-06-05) 195次浏览 已收录 0个评论

关于一个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 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:关于一个mysql_field_count的有关问题
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址