Spec-Zone .ru
спецификации, руководства, описания, API

21.8.7.47. mysql_num_fields()

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- как) оператор. Пример, показанный здесь, иллюстрирует, как это может быть сделано.

См. Раздел 21.8.15.1, "Почему mysql_store_result() Иногда Возвраты NULL После mysql_query() Успех возвратов".

Возвращаемые значения

Целое без знака, представляющее число столбцов в наборе результатов.

Ошибки

Ни один.

Пример

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. Это происходит, только если что-то пошло не так, как надо.