Основы программирования в Linux - Мэтью Нейл
fprintf(stderr, "Insert error %d: %sn", mysql_errno(&myconnection), mysql_error(&my_connection)); }<i> res = mysql_query(&my_connection, "SELECT LAST INSERT ID()");</i><i> if (res) {</i><i> printf("SELECT error %sn", mysql_error(&my_connection);</i><i> } else {</i><i> res_ptr= mysql_use_result(&my_connection);</i><i> if (res_ptr) {</i><i> while ((sqlrow = mysql_fetch_row(res_ptr))) {</i><i> printf("We inserted childno %sn", sqlrow[0]);</i><i> }</i><i> mysql_free_result(res_ptr);</i><i> }</i><i> }</i> mysql_close(&my_connection); } else { fprintf(stderr, "Connection failedn"); if (mysql_errno(&my_connection)) { fprintf(stderr, "Connection error %d: %sn", mysql_errno(&my_connection), mysql_error(&my_connection)); } } return EXIT_SUCCESS;}Далее приведен вывод:
$ <b>gcc -I/usr/include/mysql insert2.c -L/usr/lib/mysql -lmysqlclient -o insert2</b>$ <b>./insert2</b>Connection successInserted 1 rowsWe inserted childno 6$ <b>./insert2</b>Connection successInserted 1 rowsWe inserted childno 7Как это работает
После вставки строки вы извлекаете выделенный ID, применив функцию
LAST_INSERT_ID()SELECTmysql_use_result()SELECTОсновное назначение языка — конечно, извлечение данных, а не их добавление или обновление. Данные извлекаются с помощью оператора
SELECTMySQL также поддерживает SQL-операторы
SHOWDESCRIBEEXPLAINПолучение данных в вашем приложении на языке С обычно будет включать четыре шага:
1. Выполнение запроса.
2. Извлечение данных.
3. Обработка этих данных.
4. Наведение порядка при необходимости.
Так же, как в случае операторов
INSERTDELETEmysql_querymysql_store_resultmysql_use_resultmysql_fetch_rowmysql_free_resultРазница между функциями
mysql_use_resultmysql_store_resultВы сможете извлечь в единственном вызове все данные из оператора
SELECTmysql_store_result<b>MYSQL_RES *mysql_store_result(MYSQL* connection);</b>
Ясно, что вам понадобится эта функция после успешного вызова функции
mysql_queryNULLВ случае успеха вы далее вызываете функцию
mysql_num_rows<b>my_ulonglong mysql_num_rows(MYSQL_RES* result);</b>Эта функция принимает в качестве параметра структуру с результатом, возвращенную
mysql_store_resultmysql_store_resultmysql_num_rowsДанная комбинация функций — легкий способ извлечь нужные вам данные. На этом этапе все данные локальны для программы-клиента и вам не нужно больше поддерживать подключение, связанное с возможностью возникновения ошибок в сети или базе данных. Получив количество возвращенных строк, вы упростите последующий программный код.
Если окажется, что вы должны работать с особенно большим набором данных, лучше извлекать меньшие по объему, более управляемые порции данных. В этом случае приложению быстрее передается управление, и использование сетевых ресурсов будет более щадящим. Мы рассмотрим этот вариант подробнее при обсуждении функции
mysql_use_resultТеперь, когда у вас есть данные, можно обработать их с помощью функции
mysql_fetch_rowmysql_data_seekmysql_row_seekmysql_row_tell