Spec-Zone .ru
спецификации, руководства, описания, API
|
unsigned int mysql_num_fields(MYSQL_RES *result)
Передать a MYSQL*
параметр вместо этого, использовать unsigned
int mysql_field_count(MYSQL *mysql)
.
Возвращает число столбцов в наборе результатов.
Отметьте, что можно получить число столбцов или от указателя до набора результатов или к дескриптору соединения.
Вы использовали бы дескриптор соединения если mysql_store_result()
или mysql_use_result()
возвращенный NULL
(и таким
образом у Вас нет никакого указателя набора результатов). В этом случае можно вызвать mysql_field_count()
определить ли mysql_store_result()
должен был привести к непустому результату. Это
позволяет клиентской программе предпринять надлежащие меры, не зная, был ли запрос a SELECT
(или SELECT
- как) оператор. Пример, показанный здесь, иллюстрирует, как это может
быть сделано.
Целое без знака, представляющее число столбцов в наборе результатов.
Ни один.
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_errno(&mysql)) { fprintf(stderr, "Error: %s\n", mysql_error(&mysql)); } else if (mysql_field_count(&mysql) == 0) { // query does not return data // (it was not a SELECT) num_rows = mysql_affected_rows(&mysql); } }}
Альтернатива (если Вы знаете, что Ваш запрос должен был возвратить набор результатов) должна заменить mysql_errno(&mysql)
вызовите с проверкой ли mysql_field_count(&mysql)
возвраты 0. Это происходит, только если что-то пошло не так, как надо.