怎么使用DETERMINISTIC函数
这篇文章主要讲解了“怎么使用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:每次参数都发生变化因此无法缓存。
感谢各位的阅读,以上就是“怎么使用DETERMINISTIC函数”的内容了,经过本文的学习后,相信大家对怎么使用DETERMINISTIC函数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341