SQL如何对比两张表的数据?

有两个表,tableA和tableB,两个表结构相同,如下:tableA:serveriddriveriddriversize服务器1C1800服务器1D20000服务器... 有两个表,tableA和tableB,两个表结构相同,如下:
tableA:
serverid driverid driversize
服务器1 C 1800
服务器1 D 20000
服务器2 C 2000
服务器3 C 5000
服务器4 C 3000
服务器4 D 40000

tableB:
serverid driverid driversize
服务器1 C 2000
服务器1 D 21000
服务器2 C 2000
服务器3 C 5000
服务器5 C 3000

我想将以上两张表进行对比,找出tableB在tableA中没有的数据追加到tableA去,并且,在tableB中有与tableA中一样的serverid,一样的driverid,但不一样的driversize的记录,并将tableA中那条对应的表的driversize改成tableB的driversize,最后形成了新的tableA表。
求这个对比调整语句,谢谢
展开
 我来答
youngboy921
2011-01-17 · TA获得超过169个赞
知道小有建树答主
回答量:154
采纳率:0%
帮助的人:172万
展开全部
insert into tablea
select * from tablea
where not exists (selelct '1' from tableb
where tablea.serverid = serverid
and tablea.driverid = driverid
and tablea.driversize = driversize)

update tablea
set tablea.driversize = tablea.driversize
from tablea ,tableb
where tablea.serverid = serverid
and tablea.driverid = driverid

如果你以tableb为准的话,你最好在tableb上加个触发器
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式