注意三点:
1、使用前必须判断使用的内表是否为空
如果为空,就会使WHERE条件失效,相当于没有指定任何限制的取值,注意的是整个WHERE条件失效,
而不是仅仅FOR ALL ENTRIES IN 的字段。
2、默认的DISTINCT
FOR ALL ENTRIES IN 是把一个SQL分解成多个SQL去执行,然后把结果汇总去重后返回,这个去重的动作其实就是做一个DISTINCT.
注意:取值后内表的若是包含数量和金额时,需要汇总的话,要注意这一点
解决办法:加一个不会让重复数据删除的字段或者换个写法吧
3、内表大的时候占用内存会很大
如果IT_MAT很大的话,比如几百万数据,执行这个SQL占用的内存是可观的,有时候会达到内存使用的上限,而且效率很差,所以尽量避免大数据量下使用 FOR ALL ENTRIES IN吧