SELECT AJBH     A0, 
       AJMC     A1
       ---40个字段
       
  FROM GX_AJJBXX 
WHERE INSTR(BAR || ',', '202616' || ',') > 0 
   AND AJLB < '200000' 
ORDER BY DJSJ DESC 

解决方案 »

  1.   


     掌握两条条原则:
      1.where 的执行顺序从下往上过滤,先过滤数据多的。
      2.条件最好不要是= 而是>= 或<=
      

  2.   

      1. 将 =这些条件放在前面,能过滤大部分的条件
      2. 少用in ,not in 这些
      3. 使用存在的时候, 语句使用select 1 的条件;如exists(select 1 from )
      4. 连接的条件放在后面
      5。减少子表的使用,
               还有很多在你实际用的时候自己总结
       对于你的问题,加快速度的话可以增加一些索引,这样速度比较快
      

  3.   

    就索引来说,最基于INSTR(BAR || ',', '202616' || ',')函数索引,
    基于列AJLB的索引,
    当然建了索引,能否用上,还要看选择性怎么样。