日期:2014-05-16  浏览次数:20462 次

Oracle中Merge语句效率问题
大家一定都会遇到过数据库操作中的 update,
也一定会考虑过主键重复的问题,
简单的解决方法就是先 select ,
然后根据返回值判断是 insert 还是 update.
因为公司要求这个用一个语句执行,
所以调查了 oracle 自身的 merge 语句,
针对效率就调查的结果如下:
        操作次数为 1 时
        select 花费时间 47
        Merge 花费时间   0
        ------------------------------
        操作次数为 10 时
        select 花费时间 78
        Merge 花费时间  32
        ------------------------------
        操作次数为 100 时
        select 花费时间 906
        Merge 花费时间  578
        ------------------------------
        操作次数为 1000 时
        select 花费时间 6328
        Merge 花费时间  5235
        ------------------------------
        操作次数为 10000 时
        select 花费时间 71359
        Merge 花费时间 104438
        ------------------------------
        操作次数为 100000 时
        select 花费时间 1324890
        Merge 花费时间  1594922

根据PL/SQL Developer中执行来看
Merge 和 update 的效率差不多一样,
平均都是 0.015秒.
可不知道为什么 执行到后面, Merge的效率会降低.
不解.
---------
开始时怀疑是表中含有大数据量时Merge操作比较慢,
可在PL/SQL Developer中执行没有找到明显的差距.