oracleMERGEINTO...USING两表关联操作(效率高)

2014-11-24 07:36:34 来源: 作者: 浏览: 3

数据量小的时候可以使用子查询做两表关联操作;但数据量大的时候子查询效率太低(因为是单条比对)

比如:

update person1 p1 set p1.p_name=(select p_name from person2 where p1.p_id=p2.p_id)  where p1.add_date>to_date('2014-09-01','yyyy-mm-dd')
而使用MERGE INTO...USING 作两表关联操作(增、删、改)就效率非常高
MERGE INTO person1 p1 
        USING (select p_id,p_name from person2 where use='952701' ) p2
        ON ( p1.p_id=p2.p_id )    
        WHEN MATCHED THEN UPDATE SET p1.p_name = p2.p_name where p1.add_date>to_date('2014-09-01','yyyy-mm-dd')
    commit;
-->

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: