unsigned int field_count;

 field_count = 0;

 while (field_count < mysql_field_count(&my_connection)) {

  if (sqlrow[field_count]) printf("%s ", sqlrow[field_count]);

  else printf("NULL");

  field_count++;

 }

 printf("\n");

}

Когда вы откомпилируете и выполните программу, то получите следующий вывод:

$ ./select4

Connection success

Column details:

      Name: childno

      Type: Numeric field

      Max width 11

      Auto increments

      Name: fname

      Type: VARCHAR

      Max width 30

      Name: age

      Type: Numeric field

      Max width 11

Column details:

1 Jenny 21

2 Andrew 17

$

Вывод все еще не слишком привлекателен, но он демонстрирует, как можно обрабатывать и данные, и метаданные, что позволяет более эффективно работать с вашей информацией.

Есть и другие функции, позволяющие извлекать массивы полей и переходить от столбца к столбцу. Как правило, приведенные здесь подпрограммы — все, что вам потребуется; любознательный читатель сможет найти более подробную информацию в руководстве по MySQL.

<p>Разные функции</p>

Есть несколько приведенных в табл. 8.13 дополнительных функций API, которые мы рекомендуем изучить. В основном того, что обсуждалось до сих пор, достаточно для создания функциональной программы, но этот частичный перечень нам кажется полезным.

Таблица 8.13

Пример API-вызоваОписание
char *mysql_get_client_info(void);Возвращает данные о версии библиотеки, используемой клиентской программой
char *mysql_get_host_info(MYSQL *connection);Возвращает информацию о подключении к серверу
char *mysql_get_server_info(MYSQL *connection);Возвращает информацию о сервере, к которому вы в данный момент подключены
char *mysql_info(MYSQL* connection);Возвращает информацию о самом последнем выполненном запросе, но работает только с запросами нескольких типов — обычно с операторами INSERT и UPDATE. В противном случае возвращает NULL
int mysql_select_db(MYSQL *connection, const char *dbname);Заменяет базу данных, применяемую по умолчанию, на заданную в качестве параметра, при условии, что у пользователя есть соответствующие права доступа. В случае успеха возвращает ноль
int mysql_shutdown(MYSQL* connection, enum mysql_enum_shutdown level);Если у вас есть соответствующие права, завершает работу сервера базы данных, к которому вы подключены. В этот момент уровень останова следует задать равным SHUTDOWN_DEFAULT. В случае успеха возвращает ноль
<p>Приложение для работы с базой данных компакт-дисков</p>

Сейчас мы покажем, как вы можете создать простую базу данных для хранения информации о ваших компакт-дисках и затем разработать программу для доступа к этим данным. Для простоты вы ограничитесь тремя таблицами в базе данных с очень простыми связями между ними.

Начните с создания новой базы данных и затем сделайте ее текущей базой данных.

mysql> create database blpcd;

Query OK, 1 row affected (0.00 sec)

mysql> use blpcd

Connection id: 10

Current database: blpcd

mysql>

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

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

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