随笔 - 333  文章 - 1 评论 - 30 阅读 - 84万
< 2025年3月 >
23 24 25 26 27 28 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 1 2 3 4 5

 将一个表的数据插入到另外一个表中的几种情况如下:

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 from insertTest
     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  where insertTest2.id = insertTest.id;
     目标字段1,目标字段2:可以先设占位符,在设置值。也可以直接在语句中赋值
     insert into insertTest2(目标字段1,目标字段2,id,name) select  a1,
      a2, id,name from insertTest  where insertTest2.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语句会把它当做表字段,而表中不存在这个字段,会报错

 总结:即可以向一个表中查询不存在的列名,这里不存在的列名必须是实际值或占位符,不能是变量

posted on   何石-博客  阅读(7491)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示