100万条update语句
c + oracle9i
已经使用了索引
需要运行20多个小时,有什么办法可以提高效率?

解决方案 »

  1.   

    写过程在oracle中更新,c 在外部调过程,可能会快一点
      

  2.   

    update总体来说比insert要慢几点建议:
    1、如果更新的数据量接近整个表,就不应该使用index而应该采用全表扫描
    2、减少不必要的index,因为update表通常需要update index
    3、如果你的服务器有多个cpu,采用 parellel hint,可以大幅度的提高效率前年我也遇到类似的问题,300万纪录的一个表,每天要全表更新20次左右,最初通过cursor多进程(18个进程)更新,耗时30分钟,后来采用full+parallel hint,耗时降低到3分钟左右。服务器是ibm rs6000 s590,18个CPU,64GB内存。
      

  3.   

    另外,建表的参数非常重要,对于更新非常频繁的表,建议加大PCTFREE的值,以保证数据块中有足够的空间用于UPDATE,从而降低CHAINED_ROWS。