FOR ALL ENTRIES IN 应该注意的问题

注意三点:

1、使用前必须判断使用的内表是否为空

  如果为空,就会使WHERE条件失效,相当于没有指定任何限制的取值,注意的是整个WHERE条件失效,

而不是仅仅FOR ALL ENTRIES IN 的字段。

2、默认的DISTINCT

FOR ALL ENTRIES IN 是把一个SQL分解成多个SQL去执行,然后把结果汇总去重后返回,这个去重的动作其实就是做一个DISTINCT.

注意:取值后内表的若是包含数量和金额时,需要汇总的话,要注意这一点

解决办法:加一个不会让重复数据删除的字段或者换个写法吧

3、内表大的时候占用内存会很大

如果IT_MAT很大的话,比如几百万数据,执行这个SQL占用的内存是可观的,有时候会达到内存使用的上限,而且效率很差,所以尽量避免大数据量下使用 FOR ALL ENTRIES IN吧

猜你喜欢

转载自blog.csdn.net/qq_16116183/article/details/81073842
ALL
今日推荐