将⼀个表的数据插⼊到另外⼀个表中
将⼀个表的数据插⼊到另外⼀个表中的⼏种情况如下:
1.如果2张表的字段⼀致,并且希望插⼊全部数据,可以⽤这种⽅法:
INSERT INTO ⽬标表 SELECT * FROM 来源表;
例如:insert into insertTest select * from insertTest2;
2.如果只希望导⼊指定字段,可以⽤这种⽅法:
INSERT  INTO ⽬标表 (字段1, 字段2, ...) SELECT 字段1, 字段2,... FROM 来源表;(这⾥的话字段必须保持⼀致)例如:insert into insertTest2(id,name) select id,name from insertTest2;
注意:如果⽬标表与来源表主键值相同则会出现添加错误,主键值不同才能插⼊
3.如果您需要只导⼊⽬标表中不存在的记录,可以使⽤这种⽅法: 
INSERT INTO ⽬标表 (字段1, 字段2, ...) SELECT字段1, 字段2, ... FROM来源表
WHERE not exists (select * from⽬标表 where ⽬标表.⽐较字段 =来源表.⽐较字段);
例如:
1>.插⼊多条记录:
insert into  insertTest2(id,name)select id,name frominsertTest
where not exists (select * from insertTest2 where insertTest2.id=insertTest.id);
2>.插⼊⼀条记录:
insert into insertTest (id, name) SELECT 100,'liudehua'  FROM dual
WHERE not exists (select * from insertTest where insertTest.id = 100);
4、如果需要导⼊的⽬标表字段⽐来源表的字段多,将来源表的数据导⼊再加上⼏个字段组成⽬标表的数据
INSERT INTO ⽬标表(⽬标字段1,⽬标字段2,字段1, 字段2,...)
select ⽬标字段1,⽬标字段2,字段1, 字段2,... FROM来源表
⽬标字段1,⽬标字段2:这是⽬标表⽐来源表多出的字段
例如:
insert into insertTest2(⽬标字段1,⽬标字段2,id,name) select ⽬标字段1,
⽬标字段2, id,name from insertTest  whereinsertTest2.id=insertTest.id;
⽬标字段1,⽬标字段2:可以先设占位符,在设置值。也可以直接在语句中赋值
insert into insertTest2(⽬标字段1,⽬标字段2,id,name) select  a1,
sql语句怎么查询两张表的数据a2, id,name from insertTest  whereinsertTest2.id=insertTest.id;
5、对上述4的解析
select a1, a2, id,name from insertTest
这⾥在表 insertTest⾥本⾝没有a1,a2两个字段名,当使⽤这个查询语句时,会查出 insertTest表的所有字段值,并在表数据的前⾯加上了列名为a1,a2的字段,并且列名为a1的值全为a1,列名为a2的值全为a2,并且a1,a2不能为变量,如果是变量,sql语句会把它当做表字段,⽽表中不存在这个字段,会报错
总结:即可以向⼀个表中查询不存在的列名,这⾥不存在的列名必须是实际值或占位符,不能是变量