Читаем Основы программирования в Linux полностью

Типов столбца огромное множество. Полный перечень можно найти в файле mysql_com.h и в документации.

К самым распространенным относятся следующие:

FIELD_TYPE_DECIMAL

FIELD_TYPE_LONG

FIELD_TYPE_STRING

FIELD_TYPE_VAR_STRING

Далее приведен особенно полезный макрос IS_NUM, возвращающий значение true, если тип поля числовой:

if (IS_NUM(myslq_field_ptr->type)) printf("Numeric type field\n");

Прежде чем обновлять вашу программу, следует упомянуть еще одну функцию:

MYSQL_FIELD_OFFSET mysql_field_seek(MYSQL_RES* result,

 MYSQL_FIELD_OFFSET offset);

Ее можно использовать для переопределения текущего номера поля, который автоматически увеличивается при каждом вызове mysql_fetch_field. Если передать нулевое смещение, вы вернетесь назад к первому столбцу.

Теперь, имея всю необходимую информацию для написания программы выборки, покажите все дополнительные данные, относящиеся к заданному столбцу.

Далее приведена программа select4.c, которую мы воспроизводим полностью, чтобы у вас был полный пример для изучения. В программе нет расширенного анализа типов столбцов, в ней только демонстрируются требуемые основные правила.

#include

#include

#include "mysql.h"

MYSQL my_connection;

MYSQL_RES *res_ptr;

MYSQL_ROW sqlrow;

void display_header;

void display_row;

int main(int argc, char *argv[]) {

 int res;

 int first_row = 1; /* Применяется для гарантии того,

                       что мы выводим заголовок строки точно один раз,

                       когда данные успешно извлечены */

 mysql_init(&my_connection);

 if (mysql_real_connect(&my_connection, "localhost", "rick",

  "secret", "foo", 0, NULL, 0)) {

  printf("Connection success\n");

  res = mysql_query(&my_connection,

   "SELECT childno, fname, age FROM children WHERE age > 5");

  if (res) {

   fprintf(stderr, "SELECT error: %s\n", mysql_error(&my_connection));

  } else {

   res_ptr = mysql_use_result(&my_connection);

   if (res_ptr) {

    while ((sqlrow = mysql_fetch_row(res_ptr))) {

     if (first_row) {

      display_header;

      first_row = 0;

     }

     display_row;

    }

    if (mysql_errno(&my_connection)) {

     fprintf(stderr, "Retrieve error: %s\n", mysql_error(&my_connection));

    }

    mysql_free_result(res_ptr);

   }

  }

  mysql_close(&my_connection);

 } else {

  fprintf(stderr, "Connection failed\n");

  if (mysql_errno(&my_connection)) {

   fprintf(stderr, "Connection error %d: %s\n",

    mysql_errno(&my_connection), mysql_error(&my_connection))

  }

 }

 return EXIT_SUCCESS;

}

void display_header {

 MYSQL_FIELD *field_ptr;

 printf("Column details:\n");

 while ((field_ptr = mysql_fetch_field(res_ptr)) != NULL) {

  printf("\t Name: %s\n", field_ptr->name);

  printf("\t Type: ");

  if (IS_NUM(field_ptr->type)) {

   printf("Numeric field\n");

  } else {

   switch(field_ptr->type) {

   case FIELD_TYPE_VAR_STRING:

    printf("VARCHAR\n");

    break;

   case FIELD_TYPE_LONG:

    printf("LONG\n");

    break;

   default:

    printf("Type is %d, check in mysql_com.h\n", field_ptr->type);

   } /* switch */

  } /* else */

  printf("\t Max width %ld\n", field_ptr->length);

  if (field_ptr->flags & AUTO_INCREMENT_FLAG)

   printf("\t Auto increments\n");

  printf("\n");

 } /* while */

}

void display_row {

 unsigned int field_count;

Перейти на страницу:

Похожие книги

Основы программирования в Linux
Основы программирования в Linux

В четвертом издании популярного руководства даны основы программирования в операционной системе Linux. Рассмотрены: использование библиотек C/C++ и стан­дартных средств разработки, организация системных вызовов, файловый ввод/вывод, взаимодействие процессов, программирование средствами командной оболочки, создание графических пользовательских интерфейсов с помощью инструментальных средств GTK+ или Qt, применение сокетов и др. Описана компиляция программ, их компоновка c библиотеками и работа с терминальным вводом/выводом. Даны приемы написания приложений в средах GNOME® и KDE®, хранения данных с использованием СУБД MySQL® и отладки программ. Книга хорошо структурирована, что делает обучение легким и быстрым. Для начинающих Linux-программистов

Нейл Мэтью , Ричард Стоунс , Татьяна Коротяева

ОС и Сети / Программирование / Книги по IT
1001 совет по обустройству компьютера
1001 совет по обустройству компьютера

В книге собраны и обобщены советы по решению различных проблем, которые рано или поздно возникают при эксплуатации как экономичных нетбуков, так и современных настольных моделей. Все приведенные рецепты опробованы на практике и разбиты по темам: аппаратные средства персональных компьютеров, компьютерные сети и подключение к Интернету, установка, настройка и ремонт ОС Windows, работа в Интернете, защита от вирусов. Рассмотрены не только готовые решения внезапно возникающих проблем, но и ответы на многие вопросы, которые возникают еще до покупки компьютера. Приведен необходимый минимум технических сведений, позволяющий принять осознанное решение.Компакт-диск прилагается только к печатному изданию книги.

Юрий Всеволодович Ревич

Программирование, программы, базы данных / Интернет / Компьютерное «железо» / ОС и Сети / Программное обеспечение / Книги по IT