函式DETERMINISTIC

franklynzhou發表於2010-08-22

確定性函式

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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章