Oracle中的DETERMINISTIC,deterministic
多次看到DETERMINISTIC,一直很疑惑,今天做了一個實驗。我們欺騙ORACLE說是一個DETERMINISTIC函數,它在SQL中只調用一次。如果不使用DETERMINISTIC,可以看到出來的值都不一樣。使用DETERMINISTIC後,不同的會話都出來一樣的值。
SQL> create or replace function f_t(i_p int) return number DETERMINISTIC is
i_rtn number;
begin
i_rtn := i_p * dbms_random.value(1,10);
return i_rtn;
end;
/
函數已建立。
session1:
SQL> select LEVEL,f_t(1) FROM DUAL CONNECT BY LEVEL<=10;
LEVEL F_T(1)
---------- ----------
1 2.55732959
2 2.55732959
3 2.55732959
4 2.55732959
5 2.55732959
6 2.55732959
7 2.55732959
8 2.55732959
9 2.55732959
10 2.55732959
已選擇10行。
session2:
SQL> select LEVEL,f_t(1) FROM DUAL CONNECT BY LEVEL<=10;
LEVEL F_T(1)
---------- ----------
1 2.55732959
2 2.55732959
3 2.55732959
4 2.55732959
5 2.55732959
6 2.55732959
7 2.55732959
8 2.55732959
9 2.55732959
10 2.55732959
已選擇10行。
SQL> create or replace function f_t(i_p int) return number is
i_rtn number;
begin
i_rtn := i_p * dbms_random.value(1,10);
return i_rtn;
end;
/
函數已建立。
SQL> select LEVEL,f_t(1) FROM DUAL CONNECT BY LEVEL<=10;
LEVEL F_T(1)
---------- ----------
1 8.48649118
2 8.9396978
3 2.2786135
4 5.29205905
5 5.32847713
6 8.70095819
7 6.20471031
8 2.00101537
9 3.53814265
10 3.64991086
已選擇10行。
oracle中:=與=:的不同?
變數綁定 是指在sql語句的條件中使用變數而不是常量。比如shared pool裡有兩條sql語句,
select * from tab1 where col1=1;
select * from tab1 where col1=2;
對oracle資料庫來說,這是兩條完全不同的SQL,對這兩條語句都需要進行hard parse。因為oracle會根據sql語句的文本去計算每個字元在記憶體裡的hash值,因此雖然上述兩條SQL只有一個字元不一樣,oracle根據hash演算法在記憶體中得到的hash地址就不一樣,所以oracle就會認為這是兩條完全不同的語句。而如果將上述SQL改寫成select * from tab1 where col1=:var1;,然後通過對變數var1的賦值去查詢,那麼oracle對這條語句第一次會進行hard parse,以後就只進行soft parse。假設某條語句被重複執行了幾十萬次,那麼使用bind var帶來的好處是巨大的。一個應用程式如果bind var使用不充分,那麼幾乎一定會伴隨著嚴重的效能問題。
綁定變數是相對文本變數來講的,所謂文本變數是指在SQL直接書寫查詢條件,這樣的SQL在不同條件下需要反覆解析,綁定變數是指使用變數來代替直接書寫條件,查詢bind value在運行時傳遞,然後綁定執行。優點是減少硬解析,降低CPU的爭用,節省shared_pool ;缺點是不能使用histogram,sql最佳化比較困難
Oracle中 $ 幹什的
$ 在oracle常見於:
1.Regex:
它表示一行的末尾,如:
SQL> SELECT description, REGEXP_INSTR(description,'ing$') where_it_is
2 FROM testTable
3 WHERE REGEXP_INSTR(description,'ing$') > 0;
DESCRIPTION WHERE_IT_IS
---------------------------------------- -----------
2003 Movie showing 16
2. 系統檢視表/偽表:
如:sys.tab$
x$ktfbue
v$session
這些都由系統維護,使用者不能修改。