Spec-Zone .ru
спецификации, руководства, описания, API

22.8.19. C API Готовая Обработка Оператора Даты и Временных стоимостей

Двоичный файл (подготовленный оператор) протокол позволяет Вам отправить и получить дату и временные стоимости (DATE, TIME, DATETIME, и TIMESTAMP), использование MYSQL_TIME структура. Элементы этой структуры описываются в Разделе 22.8.9, "API C Готовые Структуры данных Оператора".

Чтобы отправить временные значения данных, создайте готовое использование оператора mysql_stmt_prepare(). Затем, перед вызовом mysql_stmt_execute() чтобы выполнить оператор, используйте следующую процедуру, чтобы установить каждый временный параметр:

  1. В MYSQL_BIND структура, связанная со значением данных, набор buffer_type элемент к типу, который указывает, какое временное значение Вы отправляете. Для DATE, TIME, DATETIME, или TIMESTAMP значения, набор buffer_type к MYSQL_TYPE_DATE, MYSQL_TYPE_TIME, MYSQL_TYPE_DATETIME, или MYSQL_TYPE_TIMESTAMP, соответственно.

  2. Установите buffer элемент MYSQL_BIND структура к адресу MYSQL_TIME структура, в которой Вы передаете временное значение.

  3. Заполните элементы MYSQL_TIME структура, которые являются подходящими для типа временного значения, которое передадут.

Использовать mysql_stmt_bind_param() связывать данные параметра с оператором. Затем можно вызвать mysql_stmt_execute().

Чтобы получить временные значения, процедура подобна, за исключением того, что Вы устанавливаете buffer_type элемент к типу имеющему значение Вы ожидаете получать, и buffer элемент к адресу a MYSQL_TIME структура, в которую должно быть помещено возвращенное значение. Использовать mysql_stmt_bind_result() связывать буферы с оператором после вызова mysql_stmt_execute() и прежде, чем выбрать результаты.

Вот простой пример, который вставляет DATE, TIME, и TIMESTAMP данные. mysql переменная, как предполагается, является допустимым дескриптором соединения.

  MYSQL_TIME  ts;  MYSQL_BIND  bind[3];  MYSQL_STMT  *stmt;  strmov(query, "INSERT INTO test_table(date_field, time_field, \                               timestamp_field) VALUES(?,?,?");  stmt = mysql_stmt_init(mysql);  if (!stmt)  {    fprintf(stderr, " mysql_stmt_init(), out of memory\n");    exit(0);  }  if (mysql_stmt_prepare(mysql, query, strlen(query)))  {    fprintf(stderr, "\n mysql_stmt_prepare(), INSERT failed");    fprintf(stderr, "\n %s", mysql_stmt_error(stmt));    exit(0);  }  /* set up input buffers for all 3 parameters */  bind[0].buffer_type= MYSQL_TYPE_DATE;  bind[0].buffer= (char *)&ts;  bind[0].is_null= 0;  bind[0].length= 0;  ...  bind[1]= bind[2]= bind[0];  ...  mysql_stmt_bind_param(stmt, bind);  /* supply the data to be sent in the ts structure */  ts.year= 2002;  ts.month= 02;  ts.day= 03;  ts.hour= 10;  ts.minute= 45;  ts.second= 20;  mysql_stmt_execute(stmt);  ..