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