Insert в select oracle синтаксис. Основи T-SQL. DML. Вставка кількох рядків

Крім інструкції SELECT, яка була розглянута раніше, мова маніпуляції даними DML (Data Manipulation Language) містить три інші інструкції: INSERT, UPDATE та DELETE. Подібно до інструкції SELECT ці три інструкції оперують або таблицями, або уявленнями. Ця стаття розглядає інструкцію INSERT, а дві інші інструкції розглядаються в наступній статті.

Інструкція INSERTвставляє рядки (або частини рядків) до таблиці. Існує дві різні форми цієї інструкції:

INSERT tab_name [(col_list)] DEFAULT VALUES | VALUES (( DEFAULT | NULL | expression ) [ ,...n]) INSERT INTO tab_name | view_name [(col_list)] (select_statement | execute_statement) Угоди щодо синтаксису

Перша форма інструкції дозволяє вставити в таблицю один рядок (або її частину). А друга форма інструкції INSERT дозволяє вставити в таблицю результуючий набір інструкції SELECT або процедури, що зберігається за допомогою інструкції EXECUTE. Процедура, що зберігається, повинна повертати дані для вставки в таблицю. Інструкція SELECT, що застосовується з інструкцією INSERT, може вибирати значення з іншої або тієї ж таблиці, в яку вставляються дані, за умови сумісності типів даних відповідних стовпців.

Для обох форм тип даних кожного значення, що вставляється, повинен бути сумісним з типом даних відповідного стовпця таблиці. Усі строкові та тимчасові дані мають бути укладені у лапки; чисельні значення укладати в лапки не потрібно.

Вставка одного рядка

Для обох форм інструкції INSERT явна вказівка ​​списку стовпців не є обов'язковою. Відсутність списку стовпців рівнозначно вказівкою всіх стовпців таблиці.

Параметр DEFAULT VALUESвставляє стандартні значення для всіх стовпців. У стовпці з типом даних TIMESTAMP або властивістю IDENTITY за замовчуванням вставляються значення автоматично створювані системою. Для стовпців інших типів даних вставляється відповідне ненульове значення за промовчанням, якщо таке є, або NULL в іншому випадку. Якщо для стовпця значення NULL не дозволено і для нього не визначено значення за промовчанням, виконання інструкції INSERT завершується помилкою та виводиться відповідне повідомлення.

У прикладі нижче показано вставлення рядків у таблицю Employee бази даних SampleDb, демонструючи використання інструкції INSERT для вставки невеликого обсягу даних у базу даних:

USE SampleDb; INSERT INTO Employee VALUES (34990, "Андрій", "Батонов", "d1"); INSERT INTO Employee VALUES (38640, "Олексій", "Васин", "d3");

Існує два різних способіввставляння значень у новий рядок. Інструкція INSERT у прикладі нижче явно використовує ключове слово NULL і вставляє значення NULL у відповідний стовпець:

USE SampleDb; INSERT INTO Employee VALUES (34991, "Андрій", "Батонов", NULL);

Щоб вставити значення в деякі (але не всі) стовпці таблиці, зазвичай необхідно явно вказати ці стовпці. Не зазначені стовпці мають або дозволяти значення NULL, або для них має бути визначено значення за промовчанням.

USE SampleDb; INSERT INTO Employee(Id, FirstName, LastName) VALUES (34992, "Андрій", "Батонов");

Попередні два приклади рівнозначні. У таблиці Employee єдиним стовпцем, що дозволяє значення NULL, є стовпець DepartmentNumber, а всіх інших стовпців це значення було заборонено пропозицією NOT NULL в інструкції CREATE TABLE.

Порядок значень у пропозиції VALUESІнструкції INSERT можуть відрізнятися від порядку, зазначеного в інструкції CREATE TABLE. У такому разі їхній порядок повинен співпадати з порядком, у якому відповідні стовпці перераховані у списку стовпців. Нижче показаний приклад вставки даних у порядку, що відрізняється від вихідного:

USE SampleDb; INSERT INTO Employee(DepartamentNumber, LastName, Id, FirstName) VALUES ("d1", "Батонов", 34993, "Андрій");

Вставка кількох рядків

Друга форма інструкції INSERT вставляє в таблицю один або кілька рядків, вибраних підзапитом. У прикладі нижче показано вставлення рядків у таблицю, використовуючи другу форму інструкції INSERT. В даному випадку виконується запит щодо вибірки номерів та імен відділів, розташованих у Москві, та завантаження отриманого результуючого набору в нову таблицю, створену раніше.

Нова таблиця MoscowDepartment, що створюється в прикладі вище, має ті ж стовпці, що і існуюча таблиця Department, за винятком відсутнього стовпця Location. Підзапит в інструкції INSERT вибирає у таблиці Department усі рядки, для яких значення стовпця Location дорівнює "Москва", які потім вставляються у створену на початку запиту нову таблицю.

У прикладі нижче показано ще один спосіб вставки рядків у таблицю, використовуючи другу форму інструкції INSERT. В даному випадку виконується запит на вибірку табельних номерів, номерів проектів та дат початку роботи над проектом для всіх співробітників з посадою "Менеджер", які працюють над проектом p2 з наступним завантаженням отриманого результуючого набору до нової таблиці, що створюється на початку запиту:

USE SampleDb; CREATE TABLE ManagerTeam (EmpId INT NOT NULL, ProjectNumber CHAR (4) NOT NULL, EnterDate DATE); INSERT INTO ManagerTeam (EmpId, ProjectNumber, EnterDate) SELECT EmpId, ProjectNumber, EnterDate FROM Works_on WHERE Job = "Менеджер";

Перед вставкою рядків за допомогою інструкції INSERT таблиці MoscowDepartment та ManagerTeam (у прикладах вище) були порожніми. Якщо ж таблиця вже існувала та містила рядки з даними, то до неї було б додано нові рядки.

У попередніх розділах ми розглядали роботу з отримання даних із заздалегідь створених таблиць. Тепер настав час розібрати, яким чином ми можемо створювати/видаляти таблиці, додавати нові записи і видаляти старі. Для цих цілей у SQLіснують такі оператори, як: CREATE- Створює таблицю, ALTER- Змінює структуру таблиці, DROP- видаляє таблицю чи поле, INSERT- Додає дані в таблицю. Почнемо знайомство з цією групою операторів із оператора INSERT.

1. Додавання цілих рядків

Як видно з назви, оператор INSERTвикористовується для вставки (додавання) рядків у таблицю бази даних. Додавання можна здійснити кількома способами:

  • - додати один повний рядок
  • - додати частину рядка
  • - Додати результати запиту.

Отже, щоб додати новий рядок до таблиці, нам необхідно вказати назву таблиці, перерахувати назви колонок та вказати значення для кожної колонки за допомогою конструкції INSERT INTO назва_таблиці (поле1, поле2...) VALUES (значення1, значення2...). Розглянемо з прикладу.

INSERT INTO Sellers (ID, Address, City, Seller_name, Country) VALUES("6", "1st Street", "Los Angeles", "Harry Monroe", "USA")

Також можна змінювати порядок вказівки назв колонок, однак одночасно потрібно змінювати порядок значень у параметрі VALUES.

2. Додавання частини рядків

У попередньому прикладі під час використання оператора INSERTми явно відзначали імена шпальт таблиці. Використовуючи цей синтаксис, ми можемо пропустити деякі стовпці. Це означає, що ви вводите значення для одних стовпців, але не пропонуєте їх для інших. Наприклад:

INSERT INTO Sellers (ID, City, Seller_name) VALUES("6", "Los Angeles", "Harry Monroe")

У цьому прикладі ми не вказали значення для двох стовпців Addressі Country. Ви можете виключати деякі стовпці з оператора INSERT INTOякщо це дозволяє проводити визначення таблиці. У цьому випадку має дотримуватися одна з умов: цей стовпець визначений як такий, що допускає значення NULL(відсутність будь-якого значення) або визначення таблиці вказане значення за замовчуванням. Це означає, що, якщо не вказано жодне значення, буде використано значення за промовчанням. Якщо ви пропускаєте стовпець таблиці, яка не допускає появи у своїх рядках значень NULLі не має значення, визначеного для використання за умовчанням, СУБД видасть повідомлення про помилку, і цей рядок не буде додано.

3. Додавання відібраних даних

У попередніх прикладах ми вставляли дані до таблиць, прописуючи їх вручну в запиті. Проте оператор INSERT INTOдозволяє автоматизувати цей процес, якщо ми хочемо вставляти дані з іншої таблиці. Для цього в SQL існує така кострукція як INSERT INTO ... SELECT .... Дана конструкція дозволяє одночасно вибирати дані з однієї таблиці і вставити їх в іншу. Припустимо, ми маємо ще одну таблицю Sellers_EUз переліком продавців нашого товару в Європі і нам потрібно їх додати до загальної таблиці Sellers. Структура цих таблиць однакова (та сама кількість колонок і самі їх назви), проте інші дані. Для цього ми можемо прописати наступний запит:

INSERT INTO Sellers (ID, Address, City, Seller_name, Country) SELECTID, Address, City, Seller_name, Country FROM Sellers_EU

Потрібно звернути увагу на те, щоб значення внутрішніх ключів не повторювалися (поле ID), інакше станеться помилка. Оператор SELECTтакож може містити пропозиції WHEREдля фільтрації даних Також слід зазначити, що СУБД не звертає уваги на назви колонок, що містяться в операторі SELECT, для неї важливий лише порядок їх розташування. Тому дані у першому зазначеному стовпці, що були обрані через SELECT, будуть у будь-якому випадку заповнені в перший стовпець таблиці Sellers, вказаною після оператора INSERT INTOнезалежно від назви поля.

4. Копіювання даних з однієї таблиці до іншої

Часто під час роботи з базами даних виникає потреба у створенні копій будь-яких таблиць, із єдиною метою резервування чи модифікації. Щоб зробити повну копіютаблиці в SQL передбачено окремий оператор SELECT INTO. Наприклад, нам потрібно створити копію таблиці Sellers, потрібно буде прописати запит наступним чином:

SELECT * INTO Sellers_new FROM Sellers

На відміну від попередньої конструкції INSERT INTO ... SELECT ...коли дані додаються в існуючу таблицю, конструкція копіює дані в нову таблицю. Також можна сказати, що перша конструкція імпортує дані, а друга – експортує. При використанні конструкції SELECT ... INTO ... FROM ...слід враховувати таке:

  • - можна використовувати будь-які пропозиції в операторі SELECT, такі як GROUP BYі HAVING
  • - для додавання даних із кількох таблиць можна використовувати об'єднання
  • - Дані можна додати лише одну таблицю, незалежно від того, з скількох таблиць вони були взяті.

Команда додає рядки до таблицічи подання основної таблиці.

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

Синтаксис команди Insert


Основні ключові слова та параметри команди INSERT
  • schema- ідентифікатор повноважень, що зазвичай збігається з ім'ям деякого користувача
  • table view- ім'я таблиці, в яку рядки мають бути вставлені; якщо зазначено подання, то рядки вставляються до основної таблиці подання
  • subquery_1- підзапит, який сервер обробляє тим самим способом як подання
  • column- стовпець таблиці або подання, в який для кожного вставленого рядка вводиться значення фрази VALUESчи підзапиту; якщо один із стовпців таблиці опускається з цього списку, значенням стовпця для вставленого рядка є значення за умовчанням стовпця, визначене під час створення таблиці. Якщо повністю опускається список стовпця, пропозиція VALUESабо запит повинен визначити значення для всіх стовпців у таблиці
  • VALUES- Визначає рядок значень, які будуть вставлені в таблицю або подання; значення має бути визначене у реченні VALUESдля кожного стовпця у списку стовпців
  • subquery_2- підзапит, який повертає рядки, що вставляють до таблиці; вибірковий список цього підзапиту повинен мати таку ж кількість стовпців, як у списку стовпців затвердження

Твердження із фразою VALUESдодає одиночний рядок до таблиці. Цей рядок містить значення, визначені фразою VALUES.
Твердження з підзапитомзамість фрази VALUESдодає до таблиці всі рядки, повернуті підзапитом. Сервер обробляє підзапиті вставляє кожний повернутий рядок до таблиці. Якщо підзапит не вибирає жодних рядків, сервер не вставляє жодних рядків у таблицю.
Підзапитможе звернутися до будь-якої таблиці або подання, включаючи цільову таблицю затвердження . Сервер призначає значення полям у нових рядках, заснованих на внутрішній позиції стовпців у таблиці та порядку значень фрази VALUESабо у списку вибору запиту. Якщо якісь стовпці пропущені у списку стовпців, сервер призначає їм значення за промовчанням, визначені під час створення таблиці. Якщо будь-який з цих стовпців має NOT NULL обмеження, то сервер повертає помилку, що вказує, що обмеження було порушено і скасовує затвердження INSERT.
При видачі затвердження INSERT включається будь-який INSERT - тригер, визначений таблиці.

INSERT INTO Приклад 1

INSERT INTO dept VALUES(50, «ПРОДУКЦІЯ», «САН-ФРАНЦІСКО»);

INSERT INTO Customers (city, cname, cnum) VALUES('London', 'Hoffman', 2001);

INSERT INTO Приклад 2
Нижченаведена команда копіює дані співробітників фірми, комісійні яких перевищують 25% доходу в таблицю bonus:

INSERT INTO bonus SELECT ename, job, sal, comm FROM emp WHERE comm > 0.25 * sal;

INSERT INTO Приклад 3
Якщо потрібно вставити NULL-значення, необхідно вказати його як звичайне значення так:

INSERT INTO Salespeople VALUES (1001, 'Peel',NULL,12);

INSERT INTO Приклад 4
Команду можна застосувати для того, щоб отримати значення з однієї таблиці та розмістити їх в іншій, скориставшись для цього запитом. Для цього достатньо замінити пропозицію VALUESна відповідний запит:

INSERT INTO Londonstaff SELECT * FROM Salespeople WHERE city = 'London';

MySQL INSERT

Для вставлення нових рядків у базу даних MySQL використовується команда INSERT, приклади команди наведені нижче:
INSERT INTO Приклад 1.
Вставка нового рядкатаблицю table_name.

INSERT INTO

INSERT INTO Приклад 2.
Вставка нового рядка в таблицю table_name із зазначенням вставки даних у потрібні колонки.

INSERT INTO table_name VALUES ('1','165','0','name');

У базі даних MySQLє можливість вставляти безліч нових рядків, використовуючи одну команду .
INSERT INTO Приклад 3.
Вставте кілька рядків у таблицю table_name.

INSERT INTO table_name (tbl_id, chislo, chislotwo, name) VALUES ('1','159','34','name1'), ('2','14','61','name2'), ('3 ','356','8','name3');

sql запит INSERT INTO має сенс при створеній таблиці бази даних. Тобто таблиця існує, має назву, створені рядки та стовпці. створюється таблиця оператором: модифікується таблиця оператором .

sql запит INSERT INTO - синтаксис запиту

sql запит INSERT INTO має наступний синтаксис:

INSERT INTO назва_таблиці (у дужки, якщо потрібно, вставляємо список колонок куди потрібно вставити дані) VALUES вставляються дані1, вставлені дані2, вставлені дані3.

Між INSERT та INTRO можна вставити опцію IGNORE. Вона не є обов'язковою. Потрібна для захисту первинних ключів під час редагування таблиці. Інакше, якщо при редагуванні відбувається дублювання первинних ключів, то при вставці опції IGNORE перший рядок з первинним ключем залишиться в таблиці, що змінюється, Інші первинні ключі видаляються. За замовчуванням цю опцію опускаємо.

Є необов'язкові опції LOW_PRIORITY та DELAYED. Вони визначають пріоритети додавання інформації до БД. Перша задає очікування на звільнення БД, друга означає буферизацію інформації.

Рядок у запиті: INSERT із фразою VALUES дозволить додати одиночний рядок до таблиці БД. Фраза VALUES містить значення цих даних.

Замість фрази VALUES можуть бути вказані підзапити. INSERT з підзапитом додає до таблиці рядки, повернуті підзапитом. Сервер бази даних обробляє підзапит та вставляє всі повернуті рядки в таблицю. Сервер не вставляє рядки, якщо підзапит їх не вибирає.

  • subquery_1 - підзапит, який сервер обробляє тим же способом, що і подання
  • subquery_2 - підзапит, який повертає рядки, що вставляють до таблиці. Список цього підзапиту повинен мати кількість стовпців, що збігається зі списком стовпців INSERT.

Підзапити практично не використовуються у базі даних MySQL.

Приклади SQL запиту INSERT INTO в базі даних MySQL

Вставляємо нові рядки у БД MySQL командою INSERT INTRO.

Перший приклад.

Вставляємо нові рядки у таблицю table_name.

INSERT INTO table_name VALUES ('2','145','1','name');

Це означає, що хочемо в таблицю table_name вставити в стовпці значення 2,145,1,name. Оскільки стовпці не вказані значення заполяются у всі стовпці таблиці.

Приклад другий.

Вставка інформації у потрібні (зазначені) стовпці таблиці table_name.

INSERT INTO table_name (client_customer, client_subclient, client_mail) VALUES ('name1','subname1',' [email protected]′), (‘name2′,’subname2′,’ [email protected]′), (‘name3′,’subname3′,(’ [email protected]′);

Ігор Сєров спеціально для сайту «».

Оператор INSERT вставляє нові записи до таблиці. При цьому значення стовпців можуть бути літеральними константами, або бути результатом виконання підзапиту. У першому випадку для вставки кожного рядка використовується окремий оператор INSERT; у другому випадку буде вставлено стільки рядків, скільки повертається підзапитом.

Синтаксис оператора наступний:

    INSERT INTO [ (,...) ]

    ( VALUES (,…) )

  1. | (DEFAULT VALUES)

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

    CREATE TABLE 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 не вказано значення за замовчуванням і не вказано обмеження NOT NULL , що забороняє використання NULL у даному стовпці таблиці, то означає значення за умовчанням NULL .

Виникає питання: а чи можна не вказувати список стовпців і скористатися значеннями за замовчуванням? Відповідь позитивна. Для цього потрібно замість явної вказівки значення використати зарезервоване слово DEFAULT :

    INSERT INTO Product_D

    VALUES ("B", 1158, DEFAULT);

Оскільки всі стовпці мають значення за промовчанням, для вставки рядка зі значеннями за промовчанням можна було б написати:

    INSERT INTO Product_D

    VALUES (DEFAULT, DEFAULT, DEFAULT);

Однак для цього випадку призначена спеціальна конструкція DEFAULT VALUES (див. синтаксис оператора), за допомогою якої наведений вище оператор можна переписати у вигляді

    INSERT INTO Product_D DEFAULT VALUES;

Зауважимо, що при вставці рядка в таблицю перевіряються всі обмеження, накладені на цю таблицю. Це можуть бути обмеження первинного ключа або унікального індексу, перевірочні обмеження типу CHECK, обмеження цілісності посилання. У разі порушення будь-якого обмеження вставка рядка буде відхилена. Розглянемо тепер випадок використання підзапиту. Нехай нам потрібно вставити в таблицю Product_D усі рядки з таблиці Product, що належать до моделей персональних комп'ютерів (type = PC). Оскільки необхідні нам значення вже є в деякій таблиці, то формування рядків, що вставляються вручну, по-перше, є неефективним, а, по-друге, може допускати помилки введення. Використання підзапиту вирішує ці проблеми:

Використання в підзапиті символу «*» у разі виправданим, оскільки порядок прямування стовпців є однаковим обох таблиць. Якби це було не так, слід було б застосувати список стовпців або в операторі INSERT , або в підзапиті, або в обох місцях, який приводив би у відповідність порядок прямування стовпців:

Тут, як і раніше, можна вказувати не всі стовпці, якщо потрібно використовувати наявні значення за промовчанням, наприклад:

У цьому випадку в стовпець type таблиці Product_D буде встановлено значення за замовчуванням PC для всіх рядків, що вставляються.

Зазначимо, що при використанні підзапиту, що містить предикат, будуть вставлені ті рядки, для яких значення предикату дорівнює TRUE (не UNKNOWN !). Іншими словами, якби стовпець type у таблиці Product допускав би NULL -значення, і це значення було б у рядку рядків, ці рядки були б вставлені в таблицю Product_D.

Подолати обмеження на вставку одного рядка в операторі INSERT під час використання конструктора рядка у пропозиції VALUES дозволяє штучний прийом використання підзапиту, що формує рядок із пропозицією UNION ALL . Так, якщо нам потрібно вставити кілька рядків за допомогою одного оператора INSERT, можна написати:

    INSERT INTO Product_D

    SELECT "B" AS maker, 1158 AS model, "PC" AS type

    UNION ALL

    SELECT "C", 2190, "Laptop"

    UNION ALL

    SELECT "D", 3219, "Printer";

Використання UNION ALL краще UNION навіть, якщо гарантовано відсутність рядків-дублікатів, оскільки в цьому випадку не буде перевірка для виключення дублікатів.

Слід зазначити, що вставка кількох кортежів за допомогою конструктора рядків вже реалізована в Система управління реляційними базами даних (СУБД), розроблена корпорацією Microsoft.Мова структурованих запитів) - універсальна комп'ютерна мова, що використовується для створення, модифікації та керування даними в реляційних базах даних. SQL Server 2008. З урахуванням цієї можливості останній запит можна переписати у вигляді:

    INSERT INTO Product_D VALUES

    ("B", 1158, "PC"),

    ("C", 2190, "Laptop"),


Top