mysql怎么导入ixf文件_将一个表的数据插入到另外一个表中

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

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,

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语句会把它当做表字段,而表中不存在这个字段,会报错

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值