A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘建素 中级黑马   /  2012-7-20 10:41  /  1603 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

有两张表比如a,b表两张表的结构相同 表字段都是id,name,age 如何将a表中b表没有的数据插入b表中。插入数据不能重复,不用考虑id是主键自增的问题 比如a表有条数据 为 2,张三,20,b有条数据为1,张三,20 则a表这条数据也要插入b表中。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

6 个回复

倒序浏览
insert  into  a   select  *  from  b  where  a .id<>b .id;

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
不对的跟ID没什么关系 这样插入的话会有重复出现的。
回复 使用道具 举报
id不是主键,也非自增  比如 a表有条数据为1,张三,20 b表有条数据 为 1,王五,20  你这样写的话  这条数据就会被过滤掉不会插入b中.
回复 使用道具 举报
insert into b select * from (select * from a where a.id not in (select a.id from a inner join b on a.id = b.id and a.fname = b.fname and a.age = b.age ))

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
刘秋菊 发表于 2012-7-20 12:54
insert into b select * from (select * from a where a.id not in (select a.id from a inner join b on a ...

试了下这样应该是正确的 tk.
回复 使用道具 举报
刘秋菊 发表于 2012-7-20 12:54
insert into b select * from (select * from a where a.id not in (select a.id from a inner join b on a ...

在网上查了半天使用except关键字好像更简单
insert into b select * from a except select * from b
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马