INSERT ALL: Insert Multiple Rows with a Single INSERT Statement
A quick tip to get rid of the plodding way of inserting data into a table with multiple INSERT statements. Know what I mean? Say you have a table COLORS with this structure:
| 
1 
2 
3 
4 | NameType---------------- ------------NAMEVARCHAR2(30)CATEGORY         VARCHAR2(10) | 
And you want to create this data in the table COLORS:
| 
1 
2 
3 
4 
5 
6 
7 | NAMECATEGORY------------------------------ --------yellow                         1red                            1blue                           1yellow                         2blue                           2 | 
Hands up all who write insert statements this way:
| 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 | insertintocolors (name, category)values('yellow', 1);insertintocolors (name, category)values('red', 1);insertintocolors (name, category)values('blue', 1);insertintocolors (name, category)values('yellow', 2);insertintocolors (name, category)values('blue', 2); | 
Good news for you – you can condense multiple INSERTS into a single SQL command with INSERT ALL.
INSERT ALL – the shorthand multi-table INSERT
This is how you’d do it:
| 
1 
2 
3 
4 
5 
6 
7 | insertallintocolors(name, category) values('yellow', 1)intocolors(name, category) values('red', 1)intocolors(name, category) values('blue', 1)intocolors(name, category) values('yellow', 2)intocolors(name, category) values('blue', 2)select* fromdual; | 
INSERT and INSERT ALL in action
A demo run to show identical results with the two styles:
Without INSERT ALL:
| 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 | SQL> -- Without INSERT ALLSQL> insertintocolors (name, category)  2  values('yellow', 1);1 row created.SQL> insertintocolors (name, category)  2  values('red', 1);1 row created.SQL> insertintocolors (name, category)  2  values('blue', 1);1 row created.SQL> insertintocolors (name, category)  2  values('yellow', 2);1 row created.SQL> insertintocolors (name, category)  2  values('blue', 2);1 row created.SQL> select* fromcolors;NAMECATEGORY------------------------------ ----------yellow                         1red                            1blue                           1yellow                         2blue                           2 | 
With INSERT ALL:
| 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 | SQL> -- With INSERT ALLSQL> insertall  2  intocolors(name, category) values('yellow', 1)  3  intocolors(name, category) values('red', 1)  4  intocolors(name, category) values('blue', 1)  5  intocolors(name, category) values('yellow', 2)  6  intocolors(name, category) values('blue', 2)  7  select* fromdual;5 rowscreated.SQL> select* fromcolors;NAMECATEGORY------------------------------ ----------yellow                         1red                            1blue                           1yellow                         2blue                           2 | 
 
 
No comments:
Post a Comment