-->

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

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

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

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

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

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

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()
.

mysql&gt; <b>INSERT INTO children(fname, age) VALUES('Tom', 13); </b>

Query OK, 1 row affected (0.06 sec)

mysql&gt; <b>SELECT LAST_INSERT_ID();</b>

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

| last_insert_id() |

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

|               14 |

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

1 row in set (0.01 sec)

mysql&gt; <b>INSERT INTO children(fname, age) VALUES('Harry', 17);</b>

Query OK, 1 row affected (0.02 sec)

mysql&gt; <b>SELECT LAST_INSERT_ID();</b>

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

| last_insert_id() |

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

|               15 |

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

1 row in set (0.00 sec)

mysql&gt;

Как это работает

При каждой вставке строки MySQL выделяет новое значение для столбца

id
и запоминает его, поэтому вы сможете узнать это значение с помощью функции
LAST_INSERT_ID()
.

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

SELECT LAST_INSERT_ID();
. Вы увидите, что номер не изменился, поскольку возвращаемый номер — последний, добавленный в текущем сеансе. Но если вы выполните оператор
SELECT * FROM children
, то увидите, что в другом сеансе действительно были вставлены данные.

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

Упражнение 8.3. Использование автоматически формируемых ID в программе на С

В этом примере вы измените вашу программу insert1.c, чтобы посмотреть, как она работает на С. Ключевые изменения выделены цветом. Назовите откорректированную программу insert2.c.

#include &lt;stdlib.h&gt;

#include &lt;stdio.h&gt;

#include &quot;mysql.h&quot;

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

 MYSQL my_connection;

<i> MYSQL_RES* res_ptr;</i>

<i> MYSQL_ROW sqlrow;</i>

 int res;

 mysql_init(&amp;myconnection);

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

  &quot;rick&quot;, &quot;bar&quot;, &quot;rick&quot;, 0, NULL, 0)) {

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

  res = mysql_query(&amp;my_connection,

   &quot;INSERT INTO children(fname, age) VALUES('Robert', 7)&quot;);

  if (!res) {

   printf(&quot;Inserted %lu rowsn&quot;,

    (unsigned long)mysql_affected_rows(&amp;my_connection));

  } else {

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