2011-11-23 DETERMINISTIC函数

来源:这里教程网 时间:2026-03-03 14:43:16 作者:

http://www.itpub.net/thread-1499223-18-1.html 178楼 我定义了如下函数:

FUNCTION plch_getdata (n NUMBER)
   RETURN NUMBER
IS
BEGIN
   RETURN n;
END;

哪些选项包含了这样的代码,如果我把上述函数加上DETERMINISTIC关键字,则性能会得到改善? 两点要注意: 1. 在其中一个选项中,这个函数被“重定义”为一个内嵌的子程序。 2. 其中的两个选项包含了在ALL_SOURCE执行的查询,你可以假定这个视图中有超过1,000,000行的代码。 (A)

DECLARE
   n   NUMBER;
BEGIN
   FOR rec IN (SELECT plch_getdata (1) n
                 FROM all_source
                WHERE ROWNUM < 1000000)
   LOOP
      n := rec.n;
   END LOOP;
END;
/

(B)

DECLARE
   n   NUMBER;
BEGIN
   FOR indx IN 1 .. 10000000
   LOOP
      n := plch_getdata (1);
   END LOOP;
END;
/

(C)

DECLARE
   n   NUMBER;
   FUNCTION plch_getdata (n NUMBER)
      RETURN NUMBER
      DETERMINISTIC
   IS
   BEGIN
      RETURN n;
   END;
BEGIN
   FOR indx IN 1 .. 10000000
   LOOP
      n := plch_getdata (1);
   END LOOP;
END;
/

(D)

DECLARE
   n   NUMBER;
BEGIN
   FOR rec IN (SELECT plch_getdata (ROWNUM) n
                 FROM all_source
                WHERE ROWNUM < 1000000)
   LOOP
      n := rec.n;
   END LOOP;
END;
/

答案说明在185楼 2011-11-23 答案AB.A和B都反复调用同样的函数并使用同样的参数。加上deterministic 之后, 函数结果会被缓存,只有一次调用。C:语法错误,嵌套子程序里面不可以用deterministic。D:每次参数都发生变化因此无法缓存。

相关推荐

热文推荐