[MariaDB Tutorial 번역] 17. Insert Multiple Rows (bluk insert)
[MariaDB Tutorial 번역 글]
- Select : https://rural-mouse.tistory.com/43
- Order By : https://rural-mouse.tistory.com/44
- Where : https://rural-mouse.tistory.com/45
- Distinct : https://rural-mouse.tistory.com/46
- Between : https://rural-mouse.tistory.com/48
- Like : https://rural-mouse.tistory.com/49
- In : https://rural-mouse.tistory.com/50
- Limit : https://rural-mouse.tistory.com/51
- Is Null : https://rural-mouse.tistory.com/52
- Joins : https://rural-mouse.tistory.com/53
- Inner Join : https://rural-mouse.tistory.com/54
- Left Join : https://rural-mouse.tistory.com/55
- Group By : https://rural-mouse.tistory.com/56
- Having : https://rural-mouse.tistory.com/59
- Subqueries : https://rural-mouse.tistory.com/60
- Insert : https://rural-mouse.tistory.com/61
- Insert Multiple Rows ←←
- Insert Into Select : https://rural-mouse.tistory.com/63
- Update : https://rural-mouse.tistory.com/64
원문 : https://www.mariadbtutorial.com/mariadb-basics/mariadb-insert-multiple-rows/
여기에 있는 모든 예제는 MariaDB sample database인 nation을 가지고 진행됩니다.
만약 읽고 따라 해 보시는 게 목적이라면 다운로드를 받고 읽어보시길 추천합니다.
원본 링크 : https://www.mariadbtutorial.com/getting-started/mariadb-sample-database/
MariaDB의 insert를 사용한 여러 개의 Row 삽입 명령문
하나의 insert 명령문을 사용하여 Table에 여러 개의 Row를 삽입하려면 다음의 문법을 사용하면 됩니다.
insert into
table_name(column_list)
values
(value_list_1),
(value_list_2),
(value_list_3),
...;
- 첫 번째, Table의 이름과 괄호 안에 Column 리스트를 지정합니다.
- 다음으로 쉼표( comma / , )로 구분된 Column에 해당하는 값들의 리스트를 작성합니다. 각 리스트는 Table의 Row에 해당됩니다.
MariaDB의 여러개의 row 삽입 예제
지난번에 만들었던 contact Table을 사용하도록 하겠습니다.
create table if not exists contacts(
id int auto_increment,
first_name varchar(50) not null,
last_name varchar(50) not null,
full_name varchar(101)
as (concat(first_name, ' ', last_name)) virtual,
phone varchar(100),
contact_group varchar(50) default 'General',
primary key(id)
);
A) Table에 여러 개의 Row를 삽입하는 예제
다음은 contacts Table에 3개의 row를 삽입하는 예제입니다.
insert into contacts(first_name, last_name, phone, contact_group)
values
('James','Smith','(408)-232-2352','Customers'),
('Michael','Smith','(408)-232-6343','Customers'),
('Maria','Garcia','(408)-232-3434','Customers');
MariaDB는 다음과 같은 메시지를 보여줄 것입니다.
Affected rows: 3 Found rows: 0 Warnings: 0 Duration for 1 query: 0.016 sec.
3개의 Row가 정상적으로 삽입되었다는 것을 뜻합니다.
다음은 contacts Table의 요소들을 보여주는 쿼리입니다.
select * from contacts;
B) MariaDB에서 여러개의 Row를 삽입하고 삽입된 id를 반환하는 예제
여러 개의 Row를 Table에 삽입할 때 Column이 auto_increment Column이라면 last_insert_id() 함수는 처음에 생성된 id만 반환합니다. 게다가 모든 삽입된 id들을 반환해주지 않습니다.
다음 예제를 봅시다.
처음으로 두개의 Row를 contacts Table에 삽입합니다.
insert into contacts(first_name, last_name, phone, contact_group)
values
('James','Johnson','(408)-232-4523','Customers'),
('Mary','Rodriguez','(408)-232-4532','Customers');
다음으로 table의 콘텐츠를 쿼리문을 사용하여 확인합니다.
select * from contacts;
마지막으로 last_insert_id() 함수를 사용하여 삽입된 id를 가져와봅니다.
select last_insert_id();
8이 아닌 7이 반환되었습니다.
이번 튜토리얼에서는 하나의 insert 명령문으로 여러 개의 Row를 삽입하는 방법에 대해 배워봤습니다.
다음은 Select문의 Result set을 insert를 사용하여 Table에 삽입하는 방법을 배워보겠습니다.