Справка по SQL | страница 31




INSERT Добавление записей (строк) в таблицу БД


UPDATE Обновление данных в столбце таблицы БД


DELETE Удаление записей из таблицы БД


Оператор INSERT


Оператор INSERT вставляет новые строки в таблицу. При этом значения столбцов могут представлять собой литеральные константы либо являться результатом выполнения подзапроса. В первом случае для вставки каждой строки используется отдельный оператор INSERT; во втором случае будет вставлено столько строк, сколько возвращается подзапросом.

Синтаксис оператора

INSERT INTO <имя таблицы[(<имя столбца,...)]

{VALUES (< значение столбца,…)}

| <выражение запроса

| {DEFAULT VALUES};

Как видно из представленного синтаксиса, список столбцов не является обязательным. В том случае, если он отсутствует, список вставляемых значений должен быть полный, т.е. обеспечивать значения для всех столбцов таблицы. При этом порядок значений должен соответствовать порядку столбцов, заданному оператором CREATE TABLE для таблицы, в которую вставляются строки. Кроме того, каждое из этих значений должно быть того же типа (или приводиться к нему), что и тип, определенный для соответствующего столбца в операторе CREATE TABLE. В качестве примера рассмотрим вставку строки в таблицу Product, созданную следующим оператором CREATE TABLE:


>CREATE TABLE [dbo].[product] (

> [maker] [char] (1) NOT NULL ,

> [model] [varchar] (4) NOT NULL ,

> [type] [varchar] (7) NOT NULL )


Пусть требуется добавить в эту таблицу модель ПК 1157 производителя B. Это можно сделать следующим оператором:


>INSERT INTO Product VALUES ('B', 1157, 'PC');


Если задать список столбцов, то можно изменить "естественный" порядок их следования:


>INSERT INTO Product (type, model, maker) VALUES ('PC', 1157, 'B');


Казалось бы, это совершенно излишняя возможность, которая делает конструкцию только более громоздкой. Однако она становится выигрышной, если столбцы имеют значения по умолчанию. Рассмотрим следующую структуру таблицы:


>CREATE TABLE [product_D] (

> [maker] [char] (1) NULL ,

> [model] [varchar] (4) NULL ,

> [type] [varchar] (7) NOT NULL DEFAULT 'PC' )


Отметим, что здесь значения всех столбцов имеют значения по умолчанию (первые два - NULL, а последний столбец - type - 'PC'). Теперь мы могли бы написать:


>INSERT INTO Product_D (model, maker) VALUES (1157, 'B');


В этом случае отсутствующее значение при вставке строки будет заменено значением по умолчанию - 'PC'. Заметим, что если для столбца в операторе CREATE TABLE не указано значение по умолчанию и не указано ограничение