Справочник по MySQL : SQL : Вставка строки в таблицу INSERT

смотрим также

Материал из Справочник Web-языков

Перейти к: навигация, поиск


Команда MySQL INSERT производит вставку новых строк в таблицу.

Синтаксис команды INSERT

INSERT [LOW_PRIORITY | DELAYED] [IGNORE]
    [INTO] tbl_name [(col_name,...)]
    VALUES (expression,...),(...),...

либо

INSERT [LOW_PRIORITY | DELAYED] [IGNORE]
    [INTO] tbl_name
    SET col_name=expression, col_name=expression, ...

либо

INSERT [LOW_PRIORITY | DELAYED] [IGNORE]
    [INTO] tbl_name [(col_name,...)]
    SELECT ...

Общие положения работы команды INSERT:

tbl_name
- Задает имя таблицы, в которую будет вставлена новая строка. На момент запуска команды INSERT таблица с таким именем должна существовать в базе данных.
LOW_PRIORITY
- Если указан этот параметр, то вставка новой записи будет отложена до тех пор, пока другие сценарии не закончат чтение из этой таблицы. Надо отметить, что если таблица часто используется, то при указании этого параметра может пройти достаточно много времени, прежде чем данная команда будет выполнена.
DELAYED
- Если указан этот параметр, то после выполнения команды INSERT сценарий сразу же получит ответ от БД о успешной вставке новой записи, а запись будет вставлено только после завершения использования данной таблицы другим сценарием. Это может быть удобно, если требуется высокая скорость работы скрипта. Данный параметр работает только с таблицами типа ISAM и MyISAM. Следуем отметить, что если таблица, в которую происходит вставка записи, в данный момент не используется другими запросами, то команда INSERT DELAYED будет работать медленнее, нежели INSER. Так что рекомендуется использовать параметр DELAYED только при большой нагрузке на таблицу.
IGNORE
- Если некоторые поля таблицы имеют ключи PRIMARY или UNIQUE, и производится вставка новой строки, в которой эти поля имеют дублирующее значение, то действие команды аварийно завершается и выдается ошибка №1062 ("Duplicate entry 'val' for key N"). Если в команде INSERT указано ключевое слово IGNORE, то вставка записей не прерывается, а строки с дублирующими значениями просто не вставляются.

Если MySQL был сконфигурирован с использованием опции DONT_USE_DEFAULT_FIELDS, то команда INSERT будет генерировать ошибку, если явно не указать величины для всех столбцов, которые требуют значений не-NULL.

Для того, чтобы узнать значение, присвоенное полю с ключом AUTO_INCREMENT, можно воспользоваться функцией mysql_insert_id().

Для добавления новых записей в существующую таблицу при помощи команды INSERT существует три основных синтаксиса:

INSERT ... VALUES
- В этом случае в команде четко указывается порядок следования устанавливаемых полей и их значений.
Следующая команда вставит в таблицу users новую запись, присвоив полям name, age, country, city значения Evgen, 26, Russia, Ryazan соответственно:
INSERT INTO
    `users` (`name`, `age`, `country`, `city`)
VALUES
    ('Evgen', 26, 'Russia', 'Ryazan')
Если для поля или группы полей, присутствующих в таблице, не установить значение, то используется значение, установленное по умолчанию при создании таблицы:
INSERT INTO
    `users` (`name`, `age`, `city`)
VALUES
    ('Evgen', 26, 'Ryazan')
После выполнения этой команды поле country получит значение по умолчанию.
Если при выполнении команды INSERT не были указаны названия полей, то в VALUES() должны быть указаны значения для всех полей таблицы.
Если список полей таблицы заранее не известен, то его можно узнать при помощи команды:
DESCRIBE `users`
Результатом этой команды будет таблица примерно следующего содержания:
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name    | varchar(50) | YES  |     | NULL    |       |
| age     | int(3)      | YES  |     | NULL    |       |
| country | varchar(64) | NO   |     |         |       |
| city    | varchar(64) | NO   |     |         |       |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.01 sec)
Здесь обработав полученные данные в поле Field можно получить все поля таблицы.
INSERT ... SET
- В этом случае в команде каждому полю, присутствующему в таблице, присваивается значение в виде имя поля='значение'.
Следующий пример по результату идентичен первому примеру для INSERT ... VALUE:
INSERT INTO
    `users`
SET
   `name` = 'Evgen',
   `age` = 26,
   `country` = 'Russia',
   `city` = 'Ryazan'
Так же, как и с INSERT ... VALUES, если одному или нескольким полям не задать значение, то установится значение по умолчанию.
В качестве значений полям можно присваивать не только значения, но и выражения. В выражениях разрешено использовать значения полей таблицы, которые уже были установлены в этой команде:
INSERT INTO
    `tbl_name`
SET
   `field1` = 4,
   `field2` = `field1`*`field1`
или
INSERT INTO
    `tbl_name` (`field1`, `field2`)
VALUES
    (4, `field1`*`field1`)
INSERT ... SELECT
- Такой синтаксис позволяет внести в таблицу большое количество записей за один раз, причем из разных таблиц.
Следующий пример запишет в таблицу users_new все записи из таблицы users, в которых поле country равно "Russia".
INSERT INTO
    `users_new`
SELECT
    *
FROM
    `users`
WHERE
    `country` = 'Russia'
Если для таблицы, в которую происходит вставка записей, не указан список полей, то значения для всех полей будут определены на основании результата работы SELECT.
Если некоторые поля не определены, то для них будут принято значение по умолчанию.
Особенности синтаксиса INSERT ... SELECT:
  • Имя таблицы, в которую вставляются записи, не должна присутствовать в списке таблиц FROM части SELECT, т.к. это может привести к ошибке вставки (ведь условие WHERE части SELECT может найти записи, которые уже вставлены этой командой ранее).
  • Другим сценариям запрещено производить вставку в таблицы, учавствующие в запросе, во время выполнения этого запроса.
  • Столбцы AUTO_INCREMENT работают, как обычно.
Добавить страницу в закладки:
РАЗРЕШАЕТСЯ перепечатывать и копировать информацию ТОЛЬКО ПРИ РАЗМЕЩЕНИИ ссылки на оригинал!
(<A href="https://www.spravkaweb.ru/">Справочник Web-языков</A>)
другие проекты
Rambler\'s Top100 Индекс цитирования