函数DETERMINISTIC

确定性函数

Oracle引入确定性函数的主要原因是为了提高以及函数的索引的性能,并最小化代价。因此,如果希望使用pl/sql函数使用给予函数的索引的基础,那么需要确保这个函数是确定性函数。

确定性函数的性能好处是如果使用相同的输入调用函数两次, Oracle 可以记住第一个调用的结果因此避免在第二次执行时再次调用。但是该功能直到 10g Release 2 才被真正实施[@more@]

经典例子如下:

CREATE TABLE test02(a NUMBER,b VARCHAR2(100));

INSERT INTO test02 VALUES(1,'aa');

INSERT INTO test02 VALUES(2,'bb');

INSERT INTO test02 VALUES(2,'cc');

INSERT INTO test02 VALUES(3,'dd');

CREATE SEQUENCE seq_test02;

CREATE OR REPLACE FUNCTION uf_getseq(p_number NUMBER) RETURN NUMBER DETERMINISTIC IS

v_seq NUMBER;

BEGIN

select seq_test02.nextval INTO v_seq from dual;

RETURN v_seq;

END;

/

SQL> select t.*,uf_getseq(t.a) from test02 t;

A B UF_GETSEQ(T.A)

---------- ---------- --------------

1 aa 17

2 bb 18

2 cc 18

3 dd 19

SQL>

经过上面可看到,函数参数相同时,就不再调用序列了。

再看一下另一个用处,基于自定义函数的索引:

SQL> CREATE OR REPLACE FUNCTION uf_getseq(p_number NUMBER) RETURN NUMBER IS

2 v_seq NUMBER;

3 BEGIN

4 select seq_test02.nextval INTO v_seq from dual;

5 RETURN v_seq;

6 END;

7 /

Function created

SQL> CREATE INDEX ix_a_test02 ON test02(uf_getseq(a));

CREATE INDEX ix_a_test02 ON test02(uf_getseq(a))

ORA-30553: 函数不能确定

SQL>

SQL> CREATE OR REPLACE FUNCTION uf_getseq(p_number NUMBER) RETURN NUMBER DETERMINISTIC IS

2 v_seq NUMBER;

3 BEGIN

4 select seq_test02.nextval INTO v_seq from dual;

5 RETURN v_seq;

6 END;

7 /

Function created

SQL> CREATE INDEX ix_a_test02 ON test02(uf_getseq(a));

Index created

SQL>

函数使用DETERMINISTIC后,就可创建基于自定义函数的索引了。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10455206/viewspace-1037205/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10455206/viewspace-1037205/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值