Оператором который используется для добавления строки в таблицу является
Перейти к содержимому

Оператором который используется для добавления строки в таблицу является

  • автор:

Оператор SQL INSERT: примеры и синтаксис

Аватарка пользователя Рафаил Агазода

Рассказали об операторе INSERT SQL, разобрали синтаксис оператора и рассмотрели его использование на практических примерах.

Оператор INSERT в SQL – это команда, которая используется для добавления новых записей в таблицу базы данных.

  1. Синтаксис INSERT SQL
  2. Примеры использования INSERT SQL

Синтаксис INSERT SQL

Синтаксис оператора INSERT выглядит так:

INSERT INTO название_таблицы (список_столбцов) VALUES (значения_столбцов); 

Здесь название_таблицы — это имя таблицы, в которую вы хотите вставить данные, список_столбцов — это список столбцов в таблице, в которые вы хотите вставить данные, а значения_столбцов — это значения, которые вы хотите вставить в столбцы. Значения должны соответствовать порядку, указанному в списке столбцов.

Примеры использования INSERT SQL

Предположим, у вас есть таблица “Клиенты” с тремя столбцами: “Имя”, “Фамилия” и “Email”. Вам нужно добавить нового клиента в эту таблицу. Вот как будет выглядеть запрос с оператором INSERT:

INSERT INTO Клиенты (Имя, Фамилия, Email) VALUES ('Иван', 'Иванов', 'ivan@example.com'); 

Этот запрос вставит данные нового клиента с именем “Иван”, фамилией “Иванов” и адресом электронной почты “ivan@example.com” в таблицу “Клиенты” в соответствующие столбцы.

Еще мы можем вставить сразу нескольких записей в таблицу с использованием одного оператора INSERT:

INSERT INTO Заказы (Номер, Дата) VALUES (101, '2023-01-15'), (102, '2023-01-16'), (103, '2023-01-17'); 

Кроме того, оператор INSERT можно использовать, чтобы импортировать данные из одной таблицы в другую. В примере ниже мы переносим данные из столбцов Номер и Дата в таблицу Заказы из таблицы Временные_Заказы .

INSERT INTO Заказы (Номер, Дата) SELECT Номер, Дата FROM Временные_Заказы WHERE Дата > '2023-01-01'; 

Обратите внимание, что в примере выше используется оператор WHERE. Подробнее о нем можно прочитать здесь.

Также в INSERT можно использовать подстановочные знаки:

DECLARE @Имя NVARCHAR(50) = 'Мария'; DECLARE @Фамилия NVARCHAR(50) = 'Сидорова'; INSERT INTO Клиенты (Имя, Фамилия) VALUES (@Имя, @Фамилия); 

В заключение, оператор INSERT в SQL является полезным инструментом для добавления новых данных в таблицы базы данных. Он обеспечивает простой и эффективный способ сохранения информации, обеспечивая надежное управление данными.

Оператор SQL INSERT для вставки данных в таблицу БД

Оператор SQL INSERT предназначен для вставки значений столбцов в таблицу баз данных. В результате его применения в таблице базы данных появляется новая строка.

Оператор INSERT имеет следующий синтаксис:

INSERT INTO ИМЯ_ТАБЛИЦЫ [(ИМЕНА СТОЛБЦОВ)] VALUES (ВСТАВЛЯЕМЫЕ_ЗНАЧЕНИЯ)

Квадратные скобки [], в которые заключен элемент запроса (ИМЕНА СТОЛБЦОВ), означают, что этот элемент является необязательным.

Вставка значений в таблицу с указанием или без указания столбцов

Рассмотрим подробнее применение оператора INSERT с указанием имён столбцов и без указания, остановимся на случаях, когда указывать имена столбцов всё же требуется.

Будем работать с базой данных портала объявлений. В ней есть таблица ADS, содержащая данные о объявлениях, поданных за неделю.

Если вы хотите выполнить запросы к базе данных из этого урока на MS SQL Server, но эта СУБД не установлена на вашем компьютере, то ее можно установить, пользуясь инструкцией по этой ссылке .

А скрипт для создания базы данных «Портал объявлений 1», её таблицы и заполения таблицы данных — в файле по этой ссылке .

Для использующих же MySQL приводим содержание оператора CREATE для создания таблицы:

CREATE TABLE ADS ( Id INT (11) NOT NULL DEFAULT ‘100’, Category varchar (25) DEFAULT ‘Some Category’, Part varchar (25) DEFAULT ‘Some Part’, Units INT (5) DEFAULT NULL , Money INT (10) DEFAULT NULL , PRIMARY KEY (Id) )

Пример 1. Итак, есть база данных портала объявлений. Таблица ADS выглядит так:

Id Category Part Units Money
1 Транспорт Автомашины 110 17600
2 Недвижимость Квартиры 89 18690
3 Недвижимость Дачи 57 11970
4 Транспорт Мотоциклы 131 20960
5 Стройматериалы Доски 68 7140
6 Электротехника Телевизоры 127 8255
7 Электротехника Холодильники 137 8905
8 Стройматериалы Регипс 112 11760
9 Досуг Книги 96 6240
10 Недвижимость Дома 47 9870
11 Досуг Музыка 117 7605
12 Досуг Игры 41 2665

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

INSERT INTO ADS (Id, Category, Part, Units, Money) VALUES (13, ‘Недвижимость’, ‘Гаражи’, 22, 4620)

Или без указания имён столбцов:

INSERT INTO ADS VALUES (13, ‘Недвижимость’, ‘Гаражи’, 22, 4620)

MS SQL Server в ответ на такой запрос выдаст сообщение об ошибке, так как при создании таблицы было указано, что значения столбца Id являются идентификаторами и вставляются при добавлении новых строк автоматически с приращением 1. Поэтому на MS SQL Server нужно использовать следующий запрос (можете скопировать его и вставить в окно запросов):

USE adportal1; INSERT INTO ADS (Category, Part, Units, Money) VALUES (‘Недвижимость’, ‘Гаражи’, 22, 4620);

В результате выполнения запроса в таблице появится новая строка:

13 Недвижимость Гаражи 22 4620

Из примера видно, что для вставки числовых значений в таблицу значения нужно указывать без кавычек, а для вставки строковых значений — в одинарных кавычках.

В запросе на вставку данных можно список столбцов можно указать не в том порядке, который задан при создании таблицы, и тогда данные следует указывать также в изменённом порядке.

Пример 2. Таким будет запрос на MySQL, в котором порядок следования столбцов изменён:

INSERT INTO ADS (Category, Id, Money, Part, Units) VALUES (‘Недвижимость’, 13, 4620, ‘Гаражи’, 22)

В результате выполнения запроса в таблице появится такая же новая строка, как и в примере 1.

Если вы используете MS SQL Server, то в запросе не нужно указывать столбец Id и запрос с изменённым порядком следования столбцов будет таким:

USE adportal1; INSERT INTO ADS (Category, Money, Part, Units) VALUES (‘Недвижимость’, 4620, ‘Гаражи’, 22)

Вставка значений по умолчанию (DEFAULT) и неопределённых значений (NULL)

Заметим, что при создании таблицы было предусмотрено, что значения столбцов могут иметь значения по умолчанию (DEFAULT). На MySQL для столбца Id можно предусмотреть значение 100. На MS SQL Server со строгим автоматическим приращением идентификатора это не допускается. В остальном же всё одинаково: для стобцов Category и Part значения по умолчанию — соответственно Some Category и Some Part, для столбцов Units и Money — значения NULL. Если в запросе на вставку данных на MySQL некоторые столбцы отсутствуют, то в них будут вставлены значения по умолчанию. На MS SQL в качестве значений нужно указать DEFAULT.

Пример 3. База данных и таблица — те же.

Запрос на MySQL. Вставим новые значения, указывая лишь столбец Id и его значение:

INSERT INTO ADS (Id) VALUES (14)

Все столбцы кроме Id получили значения по умолчанию. После выполнения этого запроса новая строка будет содержать следующие данные:

14 Some Category Some Part NULL NULL

На MS SQL Server такой запрос недопустим.

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

Пример 4. Запрос на MySQL. Вставим новые значения, используя ключевое слово DEFAULT и не указывая имён столбцов:

INSERT INTO ADS VALUES ( DEFAULT , DEFAULT , DEFAULT , DEFAULT , DEFAULT )

Теперь все столбцы получили значения по умолчанию. После выполнения этого запроса новая строка будет содержать следующие данные:

100 Some Category Some Part NULL NULL

Запрос на MS SQL Server (без указания столбца Id):

USE adportal1; INSERT INTO ADS VALUES ( DEFAULT , DEFAULT , DEFAULT , DEFAULT )

Вместо многократного использования слова DEFAULT можно использовать конструкцию DEFAULT VALUES, которая есть во многих диалектах SQL. Следует помнить, что в MySQL эта конструкция отсутствует.

Пример 5. Вставим новые значения, используя констукцию DEFAULT VALUES (запрос можно использовать и на MS SQL Server c предваряющей конструкцией USE adportal1):

INSERT INTO ADS DEFAULT VALUES

После выполнения этого запроса новая строка будет содержать следующие данные:

след. номер Some Category Some Part NULL NULL

Вставка значений с использованием оператора SET в MySQL

В MySQL дополнительно существует альтернативная конструкция для вставки значений в таблицу с использованием оператора SET. Она похожа на конструкцию оператора UPDATE и имеет следующий синтаксис:

INSERT INTO ИМЯ_ТАБЛИЦЫ SET ИМЯ_СТОЛБЦА_1=ЗНАЧЕНИЕ, ИМЯ_СТОЛБЦА_2=ЗНАЧЕНИЕ, . ИМЯ_СТОЛБЦА_N=ЗНАЧЕНИЕ

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

Пример 6. База данных и таблица — те же, что и в предыдущих примерах.

Вставим в таблицу строку, при этом столбцы Units и Money примут значения по умолчанию:

INSERT INTO ADS SET Category=’Недвижимость’, Part=’Гаражи’

В результате выполнения запроса в таблице появится новая строка:

13 Недвижимость Гаражи NULL NULL

Использование механизма автоматического приращения при вставке данных

Механизм автоматического приращения предназначен для автоматического генерирования уникальных значений первичного ключа в таблице. При его использовании не требуется проверять все значения первичного ключа, чтобы определить максимальное значение. При создании новой записи можно указать в качестве значения первичного ключа 0 или NULL и в таблицу будет автоматически вставлено значение, увеличенное на единицу по сравнению с максимальным значением.

В разных диалектах SQL синтаксис автоматического приращения различается. В MySQL используется ключевое слово AUTO_INCREMENT. Таблица с использованием механизма AUTO_INCREMENT в MySQL создаётся так:

CREATE TABLE ADS ( Id INT (11) NOT NULL AUTO_INCREMENT , Category varchar (25) DEFAULT ‘Some Category’, Part varchar (25) DEFAULT ‘Some Part’, Units INT (5) DEFAULT NULL , Money INT (10) DEFAULT NULL , PRIMARY KEY (Id) )

В SQL Server используется ключевое слово IDENTITY (N, M), где N — начальное значение столца, M — шаг приращения. Так, указав IDENTITY (1, 1) мы обеспечим начальное значение первичного ключа 1 и приращение на 1 значения при каждой вставке новой строки:

CREATE TABLE ADS ( Id int IDENTITY (1, 1) PRIMARY KEY , Category varchar (25) DEFAULT ‘Some Category’, Part varchar (25) DEFAULT ‘Some Part’, Units INT (5) DEFAULT NULL , Money INT (10) DEFAULT NULL )

Вставка нескольких строк в таблицу

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

Для этого применяется либо однострочный, либо многострочный оператор INSERT. Рассмотрим сначала синтаксис однострочного варианта.

Пример 7. Если используется механизм автоматического приращения значений первичного ключа, то на MySQL вставить новые строки в таблицу можно, применив несколько раз оператор INSERT и указав в качестве значений первичного ключа 0 или NULL:

INSERT INTO ADS VALUES ( NULL , ‘Электротехника’, ‘Телевизоры’, 127, 8255); INSERT INTO ADS VALUES ( NULL , ‘Электротехника’, ‘Холодильники’, 137, 8905); INSERT INTO ADS VALUES ( NULL , ‘Стройматериалы’, ‘Регипс’, 112, 11760); INSERT INTO ADS VALUES ( NULL , ‘Досуг’, ‘Книги’, 96, 6240);

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

6 Электротехника Телевизоры 127 8255
7 Электротехника Холодильники 137 8905
8 Стройматериалы Регипс 112 11760
9 Досуг Книги 96 6240

На MS SQL Server нет необходимости указывать значения столбца Id. Аналогичный запрос будет следующим:

USE adportal1; INSERT INTO ADS VALUES (‘Электротехника’, ‘Телевизоры’, 127, 8255); INSERT INTO ADS VALUES (‘Электротехника’, ‘Холодильники’, 137, 8905); INSERT INTO ADS VALUES (‘Стройматериалы’, ‘Регипс’, 112, 11760); INSERT INTO ADS VALUES (‘Досуг’, ‘Книги’, 96, 6240);

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

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

Запрос на MySQL:

INSERT INTO ADS VALUES ( NULL , ‘Электротехника’, ‘Телевизоры’, 127, 8255), ( NULL , ‘Электротехника’, ‘Холодильники’, 137, 8905), ( NULL , ‘Стройматериалы’, ‘Регипс’, 112, 11760), ( NULL , ‘Досуг’, ‘Книги’, 96, 6240);

Запрос на MS SQL Server:

USE adportal1; INSERT INTO ADS VALUES (‘Электротехника’, ‘Телевизоры’, 127, 8255), (‘Электротехника’, ‘Холодильники’, 137, 8905), (‘Стройматериалы’, ‘Регипс’, 112, 11760), (‘Досуг’, ‘Книги’, 96, 6240);

Результат применения — тот же, что и в предыдущем примере.

Примеры запросов к базе данных «Портал объявлений-1» есть также в уроках об операторах UPDATE, DELETE, HAVING и UNION.

Оператором который используется для добавления строки в таблицу является

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

MySQL
INSERT INTO имя_таблицы [(поле_таблицы, ...)] VALUES (значение_поля_таблицы, ...) | SELECT поле_таблицы, ... FROM имя_таблицы ... 

Значения можно вставлять перечислением с помощью слова VALUES , перечислив их в круглых скобках через запятую или c помощью оператора SELECT .

Таким образом, добавить новые записи можно следующими способами:

  • Используя синтаксис INSERT INTO . SELECT
MySQL
INSERT INTO Goods (good_id, good_name, type) SELECT 20, 'Table', 2; 
MySQL
INSERT INTO Goods (good_id, good_name, type) VALUES (20, 'Table', 2); 

Каждый из этих запросов даст одинаковый результат:

good_id good_name type
1 apartment fee 1
2 phone fee 1
3 bread 2
4 milk 2
5 red caviar 3
6 cinema 4
7 black caviar 3
8 cough tablets 5
9 potato 2
10 pineapples 3
11 television 8
12 vacuum cleaner 8
13 jacket 7
14 fur coat 7
15 music school fee 6
16 english school fee 6
20 Table 2

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

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

MySQL
INSERT INTO Goods SELECT COUNT(*) + 1, 'Table', 2 FROM Goods; 

В MySQL введён механизм его автоматической генерации. Для этого достаточно снабдить первичный ключ good_id атрибутом AUTO_INCREMENT . Тогда при создании новой записи в качестве значения good_id достаточно передать NULL или 0 — поле автоматически получит значение, большее предыдущего на единицу.

MySQL
CREATE TABLE Goods ( good_id INT NOT NULL AUTO_INCREMENT ... ); 
MySQL
INSERT INTO Goods VALUES (NULL, 'Table', 2); 

В PostgreSQL есть схожий механизм для автоматической генерации уникального идентификатора. Для этого он имеет типы SMALLSERIAL , SERIAL , BIGSERIAL , которые не являются настоящими типами, а скорее просто удобством записи столбцов с уникальным идентификатором. Столбец с одним из вышеперечисленных типов будет являться целочисленным и автоматически увеличиваться при добавлении новой записи.

MySQL
CREATE TABLE Goods ( good_id SERIAL ... ); 
MySQL
INSERT INTO Goods (good_name, type) VALUES ('Table', 2); 

INSERT и SELECT – добавление и выборка данных

То есть CRUD обозначает четыре базовых действия с данными, хранимыми в таблицах БД.

При этом операторы языка SQL не обязательно совпадают со словами create, read, update, delete. Так в SQL нет оператора READ, вместо него используется SELECT. Записи-строки в таблицу вставляются не с помощью CREATE, а оператором INSERT.

Оператор INSERT

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

INSERT INTO (, , . ) VALUES (, , …);

После INSERT INTO указывается имя таблицы, после в скобках перечисляются столбцы. После слова VALUES перечисляются данные, вставляемые в поля столбцов. Например:

sqlite> INSERT INTO sections . > (_id, name) VALUES . > (1, 'information');

При этом столбцы не обязательно должны перечисляться в том же порядке, в котором задавались при создании таблицы:

sqlite> INSERT INTO sections . > (name, _id) . > VALUES . > ('Boolean Algebra', 3);

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

sqlite> INSERT INTO sections . > VALUES (2, 'Digital Systems');

INSERT INTO

Если в таблице есть столбцы с ограничителями AUTOINCREMENT и DEFAULT, то есть автозаполняемые, значения для них можно не указывать. Однако в этом случае должен быть указан перечень столбцов для остальных значений:

sqlite> INSERT INTO pages VALUES . > (1, 'What is Information', . > 'information', 1, 1); sqlite> INSERT INTO pages . > (title, url, theme, num) . > VALUES . > ('Amount of Information', . > 'amount-information', 1, 2);

Здесь в первом случае мы вручную задаем значение для поля _id и передаем данные во все остальные поля. Поэтому можем опустить перечисление столбцов. Во втором случае СУБД будет самостоятельно заполнять поле _id. Во избежание неоднозначности мы должны перечислить остальные столбцы.

Обратите внимание, в SQLite мы должны включать поддержку внешнего ключа, чтобы работал ограничитель FOREIGN KEY и не давал нам добавлять записи с номерами тем, которых нет в таблице sections.

Причина, по которой СУБД присвоила второй записи идентификатор 3, а не 2, заключается в том, что раньше в таблицу уже помещались данные, но были удалены.

Оператор SELECT

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

SELECT * FROM ;

Такая команда отображает значения всех столбцов и строк заданной таблицы. На выборку всех столбцов указывает звездочка после слова SELECT. А все строки будут выбраны потому, что после имени таблицы нет оператора WHERE языка SQL. WHERE позволяет задавать условие, согласно которому отображаются только удовлетворяющие ему строки.

Утилита sqlite3 позволяет отображать данные таблицы в различных форматах, которые задаются с помощью команды .mode, после которой указывается необходимый режим. Команда .mode без аргумента показывает текущий режим.

Обратите внимание, на скринах выше разделителями между столбцами является вертикальная черта. Это режим list. Посмотреть все доступные режимы можно с помощью команды .help .mode .

Чтобы отобразить заголовки используется команда .header on . Они хорошо сочетаются с режимом column. Для отключения заголовков используется .header off :

Режим column с заголовком

Когда требуется просмотреть только отдельные столбцы, то вместо звездочки их имена перечисляются через запятую:

sqlite> SELECT title, theme FROM pages; What is Information|1 Amount of Information|1

WHERE

Условие WHERE используется не только с оператором SELECT, также с UPDATE и DELETE. С помощью WHERE определяются строки, которые будут выбраны, обновлены или удалены. По сути это фильтр.

После ключевого слова WHERE записывается логическое выражение, которое может быть как простым (содержащим операторы = или ==, >, =,

sqlite> SELECT * FROM pages . > WHERE _id == 3; sqlite> SELECT * FROM pages WHERE . > theme == 2 AND num == 100; sqlite> SELECT * FROM pages WHERE . > theme 

Примеры с BETWEEN и IN:

sqlite> SELECT _id, title . > FROM pages WHERE . > _id BETWEEN 2 AND 8; 3|Amount of Information 4|Binary System 5|Octal System 6|Lows of Logic Algebra sqlite> SELECT _id, title . > FROM pages WHERE . > _id IN (1,2); 1|What is Information sqlite> SELECT _id, title . > FROM pages WHERE . > _id NOT IN (1,3); 4|Binary System 5|Octal System 6|Lows of Logic Algebra

ORDER BY

При выводе данных их можно не только фильтровать с помощью WHERE, но и сортировать по возрастанию или убыванию с помощью оператора ORDER BY.

sqlite> SELECT url, title, theme . > FROM pages . > ORDER BY url ASC; amount-information|Amount of Information|1 binary|Binary System|2 information|What is Information|1 logic-low|Lows of Logic Algebra|3 octal|Octal System|2 sqlite> SELECT url, title FROM pages . > WHERE theme == 1 . > ORDER BY url DESC; information|What is Information amount-information|Amount of Information

ASC – сортировка от меньшего значения к большему. DESC – сортировка от большего значения к меньшему.

Сортировка - ORDER BY

X Скрыть Наверх

Введение в реляционные базы данных. SQLite

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *