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

22.8.7.22. mysql_field_count()

unsigned int mysql_field_count(MYSQL *mysql)

Описание

Возвращает число столбцов для нового запроса на соединении.

Нормальная эксплуатация этой функции то, когда mysql_store_result() возвращенный NULL (и таким образом у Вас нет никакого указателя набора результатов). В этом случае можно вызвать mysql_field_count() определить ли mysql_store_result() должен был привести к непустому результату. Это позволяет клиентской программе предпринять надлежащие меры, не зная, был ли запрос a SELECT (или SELECT- как) оператор. Пример, показанный здесь, иллюстрирует, как это может быть сделано.

См. Раздел 22.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_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_field_count(&mysql) вызовите с mysql_errno(&mysql). В этом случае Вы проверяете непосредственно на ошибку от mysql_store_result() вместо того, чтобы выводить из значения mysql_field_count() был ли оператор a SELECT.