Spec-Zone .ru
спецификации, руководства, описания, API
|
unsigned int mysql_field_count(MYSQL *mysql)
Возвращает число столбцов для нового запроса на соединении.
Нормальная эксплуатация этой функции то, когда mysql_store_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_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
.