千家信息网

怎么使用DETERMINISTIC函数

发表于:2024-10-27 作者:千家信息网编辑
千家信息网最后更新 2024年10月27日,这篇文章主要讲解了"怎么使用DETERMINISTIC函数",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么使用DETERMINISTIC函数"吧!我
千家信息网最后更新 2024年10月27日怎么使用DETERMINISTIC函数

这篇文章主要讲解了"怎么使用DETERMINISTIC函数",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么使用DETERMINISTIC函数"吧!

我定义了如下函数:

FUNCTION plch_getdata (n NUMBER)   RETURN NUMBERISBEGIN   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函数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

0