Чтение онлайн

на главную - закладки

Жанры

Основы программирования в Linux
Шрифт:

fprintf(stderr, "Insert error %d: %s\n",

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

}

mysql_close(&my_connection);

 } else {

fprintf(stderr, "Connection failed\n");

if (mysql_errno(&my_connection)) {

printf(stderr, "Connection error %d: %s\n",

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

}

 }

 return EXIT_SUCCESS;

}

Как и ожидалось, одна строка добавлена.

Теперь измените код, чтобы включить

UPDATE
вместо
INSERT
, и посмотрите на сообщение об измененных строках.

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

 }

}

res = mysql_query(&my_connection,

 "UPDATE children SET AGE = 4 WHERE fname = 'Ann'");

if (!res) {

 printf("Updated %lu rows\n",

(unsigned long)mysql_affected_rows(&my_connection));

} else {

 fprintf (stderr, "Update error %d: %s\n",

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

}

Назовите эту программу update1.c. Она пытается задать возраст 4 года для всех детей с именем Ann.

Предположим, что ваша таблица

children
содержит следующие данные:

mysql> SELECT * from CHILDREN;

+---------+--------+-----+

| childno | fname | age |

+---------+--------+-----+

| 1 | Jenny | 21 |

| 2 | Andrew | 17 |

| 3 | Gavin | 9 |

| 4 | Duncan | 6 |

| 5 | Emma | 4 |

| 6 | Alex | 15 |

| 7 | Adrian | 9 |

| 8 | Ann | 3 |

| 9 | Ann | 4 |

| 10 | Ann | 3 |

| 11 | Ann | 4 |

+---------+--------+-----+

11 rows in set (0.00 sec)

В вашей таблице есть четыре ребенка с именем Ann. Вы можете рассчитывать на то, что при выполнении программы update1 количество измененных строк будет равно четырем, т.е. числу строк, отбираемых по условию

WHERE
. Но если вы выполните программу, то увидите отчет программы об изменении только двух строк, поскольку учитываются только те строки, данные которых действительно нуждались в корректировке. Можно выбрать более традиционный вариант отчета, используя флаг
CLIENT_FOUND_ROWS
в функции
mysql_real_connect
:

if (mysql_real_connect(&my_connection, "localhost",

 "rick", "secret", "foo", 0, NULL, CLIENT_FOUND_ROWS)) {

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

Последняя странность функции

mysql_affected_rows
проявляется при удалении информации из базы данных. Если вы удаляете данные с помощью условия
WHERE
,
mysql_affected_rows
вернет ожидаемое вами количество удаленных строк. Но если в операторе
DELETE
нет условия
WHERE
, будут удалены все строки, но в сообщении программы о количестве строк, затронутых запросом, будет указан ноль. Это происходит потому, что MySQL оптимизирует удаление всех строк, заменяя многократные построчные удаления.

На подобное поведение не влияет флаг

CLIENT_FOUND_ROWS
.

Что же вы вставили?

Существует небольшая, но важная особенность вставки данных. Ранее мы упоминали столбец типа

AUTO_INCREMENT
, в который MySQL автоматически вставляет идентификаторы. Это свойство весьма полезно, особенно при наличии нескольких пользователей.

Рассмотрим определение таблицы еще раз:

CREATE TABLE children (

 childno INTEGER AUTO_INCREMENT NOT NULL PRIMARY KEY,

 fname VARCHAR(30),

 age INTEGER

);

Как видите, столбец

childno
— поле типа
AUTO_INCREMENT
. Это замечательно, но когда вы вставили строку, как узнать, какой номер присвоен ребенку, чье имя вы только что вставили?

Можно выполнить оператор

SELECT
для того чтобы извлечь данные, отобранные по имени ребенка. Но это очень неэффективный способ и не гарантирующий уникальности выбора: допустим, что у вас есть два ребенка с одним и тем же именем. Или несколько пользователей могли быстро вставить данные, и появились другие добавленные строки между вашим оператором обновления и оператором
SELECT
. Поскольку выяснение значения столбца типа
AUTO_INCREMENT
— столь распространенная проблема, MySQL предлагает специальное решение в виде функции
LAST_INSERT_ID
.

Когда MySQL вставляет данные в столбец типа

AUTO_INCREMENT
, она отслеживает для каждого пользователя последнее присвоенное ею значение. Программы пользователей могут узнать его, просто используя в операторе
SELECT
специальную функцию
LAST_INSERT_ID
, которая действует немного похоже на псевдостолбец.

Выполните упражнение 8.2.

Упражнение 8.2. Извлечение ID, сгенерированного в столбце типа
AUTO_INCREMENT

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

LAST_INSERT_ID
.

Поделиться:
Популярные книги

Точка Бифуркации VIII

Смит Дейлор
8. ТБ
Фантастика:
фэнтези
попаданцы
5.00
рейтинг книги
Точка Бифуркации VIII

Глэрд VIII: Базис 2

Владимиров Денис
8. Глэрд
Фантастика:
фэнтези
боевая фантастика
попаданцы
5.00
рейтинг книги
Глэрд VIII: Базис 2

Воронцов. Перезагрузка. Книга 2

Тарасов Ник
2. Воронцов. Перезагрузка
Фантастика:
попаданцы
альтернативная история
фэнтези
5.00
рейтинг книги
Воронцов. Перезагрузка. Книга 2

Чехов. Книга 2

Гоблин (MeXXanik)
2. Адвокат Чехов
Фантастика:
фэнтези
альтернативная история
аниме
5.00
рейтинг книги
Чехов. Книга 2

Шайтан Иван 5

Тен Эдуард
5. Шайтан Иван
Фантастика:
попаданцы
альтернативная история
историческое фэнтези
5.00
рейтинг книги
Шайтан Иван 5

Московское золото или нежная попа комсомолки. Часть Вторая

Хренов Алексей
2. Летчик Леха
Фантастика:
попаданцы
5.00
рейтинг книги
Московское золото или нежная попа комсомолки. Часть Вторая

Ищу жену с прицепом

Рам Янка
2. Спасатели
Любовные романы:
современные любовные романы
6.25
рейтинг книги
Ищу жену с прицепом

Адвокат Империи 14

Карелин Сергей Витальевич
14. Адвокат империи
Фантастика:
городское фэнтези
аниме
попаданцы
5.00
рейтинг книги
Адвокат Империи 14

Дракон - не подарок

Суббота Светлана
2. Королевская академия Драко
Фантастика:
фэнтези
6.74
рейтинг книги
Дракон - не подарок

Бальмануг. (Не) Любовница 2

Лашина Полина
4. Мир Десяти
Любовные романы:
любовно-фантастические романы
5.00
рейтинг книги
Бальмануг. (Не) Любовница 2

Бандит

Щепетнов Евгений Владимирович
1. Петр Синельников
Фантастика:
фэнтези
7.92
рейтинг книги
Бандит

Я еще не барон

Дрейк Сириус
1. Дорогой барон!
Фантастика:
боевая фантастика
попаданцы
аниме
5.00
рейтинг книги
Я еще не барон

Кодекс Охотника. Книга XV

Винокуров Юрий
15. Кодекс Охотника
Фантастика:
попаданцы
аниме
5.00
рейтинг книги
Кодекс Охотника. Книга XV

Барон отрицает правила

Ренгач Евгений
13. Закон сильного
Фантастика:
аниме
фэнтези
фантастика: прочее
попаданцы
5.00
рейтинг книги
Барон отрицает правила