Литмир - Электронная Библиотека
Содержание  
A
A

□ Функция

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 success\n&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: %s\n&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 rows\n&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: %s\n&quot;,

      mysql_error(&amp;my_connection));

    }

    mysql_free_result(res_ptr);

   }

  }

  mysql_close(&amp;my_connection);

 } else {

  fprintf(stderr, &quot;Connection failed\n');

  if (mysql_errno(&amp;my_connection)) {

   fprintf(stderr, &quot;Connection error %d: %s\n&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
, последующие операции в вашей программе, направленные на извлечение данных, могут вернуть поврежденную информацию.

152
{"b":"285844","o":1}