select into from 和 insert into select都被用来复制表结构和表中数据,
两者的主要区别为:
select into from 要求目标表不存在,因为在插入时会自动创建。
insert into select from 要求目标表已存在数据库中。
一、INSERT INTO SELECT语句
1、语句形式为:
1、语句形式为:
Insert into Table2(field1,field2,...) select value1,value2,... from Table1;
2、注意点:
(1)要求目标表Table2必须存在,并且要复制的字段field,field2...也必须存在
(2)注意Table2的主键约束,如果Table2有主键且不为空,则 field1, field2...中必须包括主键
(3)注意区分 Insert into Table2(field1,field2,...) values (select value1,value2,... from Table1);
2、注意点:
(1)要求目标表Table2必须存在,并且要复制的字段field,field2...也必须存在
(2)注意Table2的主键约束,如果Table2有主键且不为空,则 field1, field2...中必须包括主键
(3)注意区分 Insert into Table2(field1,field2,...) values (select value1,value2,... from Table1);
二、SELECT INTO FROM语句
1、语句形式为:
SELECT vale1,value2 into Table2 from Table1;
2、注意点:
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中 。
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中 。
3、应用实例:
SELECT name as iName, 0 as iAge,phone as iPhone
INTO table2
FROM table1;
上面的例子:将会复制表1的结构,而且会把name字段改成iName,phone字段改成IPhone并添加IAge字段(0对应int类型)到新表table2中,对于复制表结构的同时需要增加新的列并插入数据的情形很可以用此语句。