-->

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

На нашем литературном портале можно бесплатно читать книгу Основы программирования в Linux, Мэтью Нейл-- . Жанр: Программирование / ОС и Сети. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале bazaknig.info.
Основы программирования в Linux
Название: Основы программирования в Linux
Дата добавления: 16 январь 2020
Количество просмотров: 670
Читать онлайн

Основы программирования в Linux читать книгу онлайн

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

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала

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

□ Функция

mysql_fetch_row
извлекает одну строку из структуры типа
result
, которую вы получили с помощью функции
mysql_store_result
, и помещает ее структуру
row
. Когда данные иссякли или возникла ошибка, возвращается
NULL
. В следующем разделе мы вернемся к обработке данных в структуре типа
row
.

<b>MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);</b>

□ Функция

mysql_data_seek
позволяет перемещаться в результирующем наборе, задавая строку, которая будет возвращена при следующем вызове функции
mysql_fetch_row
. Значение
offset
— номер строки в диапазоне от нуля до общего количества строк в результирующем наборе, уменьшенного на единицу. Передача нулевого значения вызовет возврат первой строки при следующем вызове функции
mysql_fetch_row
.

<b>void mysql_data_seek(MYSQL_RES *result, my_ulonglong offset);</b>

□ Функция

mysql_row_tell
возвращает величину смещения, обозначая текущую позицию в результирующем наборе. Это не номер строки и его нельзя использовать в функции
mysql_data_seek
.

<b>MSSQL_ROW_OFFSET mysql_row_tell(MYSQL_RES *result);</b>

Но ее можно применять с функцией

<b>MYSQL_ROW_OFFSET mysql_row_seek(MYSQL_RES *result,</b>

<b> MYSQL_ROW_OFFSET offset);</b>

которая перемещает текущую позицию в результирующем наборе и возвращает предыдущую позицию.

Примечание

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

row_tell
и
row_seek
со значением смещения, применяемым в функции
data_seek
. Иначе ваши результаты будут непредсказуемыми.

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

mysql_free_result
, позволяющую библиотеке MySQL навести после себя порядок.

<b>void mysql_free_result(MYSQL_RES *result);</b>

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

Извлечение данных

Теперь вы можете написать свое первое приложение с выборкой данных. Вы. хотите выбрать все записи, в которых возраст ребенка более 5 лет. Пока вы еще не знаете, как обработать эти данные, поэтому начнем с простого их извлечения. Важный фрагмент, в котором вы считываете результирующий набор и выводите в цикле полученные данные, выделен цветом. Далее приведена программа select1.с.

#include &lt;stdlib.h&gt;

#include &lt;stdio.h&gt;

#include &quot;mysql.h&quot;

MYSQL my_connection;

MYSQL_RES *res_ptr;

MYSQL_ROW sqlrow;

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

 int res;

 mysql_init(&amp;my_connection);

 if (mysql_real_connect(&amp;my_connection, &quot;localhost&quot;, &quot;rick&quot;,

  &quot;secret&quot;, &quot;foo&quot;, 0, NULL, 0)) {

  printf(&quot;Connection successn&quot;);

  res = mysql_query(&amp;my_connection,

   &quot;SELECT childno, fname, age FROM children WHERE age &gt; 5&quot;);

  if (res) {

   printf(&quot;SELECT error: %sn&quot;, mysql_error(&amp;my_connection));

  } else {

<i>   res_ptr = mysql_store_result(&amp;my_connection);</i>

<i>   if (res_ptr) {</i>

<i>    printf(&quot;Retrieved %lu rowsn&quot;,</i>

<i>     (unsigned long)mysql_num_rows(res_ptr));</i>

<i>    while ((sqlrow = mysql_fetch_row(res_ptr))) {</i>

<i>     printf(&quot;Fetched data...n&quot;);</i>

<i>    }</i>

    if (mysql_errno(&amp;my_connection)) {

     fprintf(stderr, &quot;Retrieve error: %sn&quot;,

      mysql_error(&amp;my_connection));

    }

    mysql_free_result(res_ptr);

   }

  }

  mysql_close(&amp;my_connection);

 } else {

  fprintf(stderr, &quot;Connection failedn');

  if (mysql_errno(&amp;my_connection)) {

   fprintf(stderr, &quot;Connection error %d: %sn&quot;,

    mysql_errno(&amp;my_connection), mysql_error(&amp;my_connection));

  }

 }

 return EXIT_SUCCESS;

}

Построчное извлечение данных

Для извлечения данных строка за строкой, если вы действительно хотите этого, пользуйтесь функцией

mysql_use_result
вместо функции
mysql_store_result
.

<b>MYSQL_RES *mysql_use_result(MYSQL *connection);</b>

Как и

mysql_store_result
, функция
mysql_use_result
в случае ошибки возвращает
NULL
; если она выполняется успешно, то возвращает указатель на объект с результирующим набором. Но эта функция отличается тем, что не считывает никаких данных в результирующий набор, который инициализировала.

Примечание

Для того чтобы действительно получить данные, следует многократно применять функцию

mysql_fetch_row
до тех пор, пока все данные не будут извлечены. Если вы не получите все данные от функции
mysql_use_result
, последующие операции в вашей программе, направленные на извлечение данных, могут вернуть поврежденную информацию.

Перейти на страницу:
Комментариев (0)
название