这篇文章主要讲解了“怎么使用DETERMINISTIC函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用DETERMINISTIC函数”吧!
我定义了如下函数:
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; /
答案AB.
A和B都反复调用同样的函数并使用同样的参数。加上deterministic 之后, 函数结果会被缓存,只有一次调用。
C:语法错误,嵌套子程序里面不可以用deterministic。
D:每次参数都发生变化因此无法缓存。