您的位置:首页 > 其它

根据条件用一个表的字段,去更新另一个表的字段

2012-10-09 18:44 453 查看
注意ON关联值不能重复。

SELECT A.A1,A.A2,B.B1,B2 FROM TABLEA A
LEFT JOIN TABLEB B
ON A.A1 = B.B1
WHERE A.A2 IS NULL AND B.B2 IS NOT NULL

------------------------------------

MERGE INTO TABLEA A
USING TABLEB  B
ON (A.A1 = B.B1 )
WHEN MATCHED AND A.A2 IS NULL AND B.B2 IS NOT NULL THEN
UPDATE SET A.A2=B.B2
--这个比UPDATE的好处就是只全表扫描一次,还可以一次性做多个操作,如UPDATE,INSTER,DELETE
--WHEN NOT MATCHED THEN
--INSERT....


数据量少的情况下,容易理解的

UPDATE A a  SET(A1) = (SELECT b.B1 FROM B b where  a.ID=b.ID)
WHERE EXISTS (SELECT 1 FROM B b WHERE a.ID = b.ID);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐