Oracle 11g的新特性:虛擬列
今天我將為大家解釋 Oracle 11g 數(shù)據(jù)庫(kù)的新特性 —— 虛擬列
介紹
在老的 Oracle 版本,當(dāng)我們需要使用表達(dá)式或者一些計(jì)算公式時(shí),我們會(huì)創(chuàng)建數(shù)據(jù)庫(kù)視圖,如果我們需要在這個(gè)視圖上使用索引,我們會(huì)創(chuàng)建基于函數(shù)的索引。
現(xiàn)在 Oracle 11g 允許我們直接在表上使用虛擬列來(lái)存儲(chǔ)表達(dá)式。
來(lái)看一個(gè)簡(jiǎn)單的例子:
- CREATE TABLE EMP
- (
- EMPNO NUMBER(6),
- SAL NUMBER(8,2),
- COMM NUMBER(8,2),
- SAL_PACK GENERATED ALWAYS AS ( SAL + NVL(COMM,0) ) VIRTUAL
- );
上述建的虛擬列 SAL_PACK 是由一個(gè)簡(jiǎn)單的表達(dá)式創(chuàng)建的,使用的關(guān)鍵字有 VIRTUAL(不過(guò)這個(gè)關(guān)鍵字是可選的),該字段的值是由 COMM 這個(gè)字段通過(guò)表達(dá)式計(jì)算而來(lái)的。
虛擬列的值是不存儲(chǔ)在磁盤(pán)的,它們是在查詢時(shí)根據(jù)定義的表達(dá)式臨時(shí)計(jì)算的。
我們不能往虛擬列中插入數(shù)據(jù):
- SQL> INSERT INTO emp VALUES (10, 1500, 500,2000);
- ERROR at line 1:
- ORA-54013: INSERT operation disallowed on virtual columns
我們也不能隱式的添加數(shù)據(jù)到虛擬列:
- SQL> INSERT INTO t VALUES (10, 1500, 500);
- *
- ERROR at line 1:
- ORA-00947: not enough values
我們只能使用物理列來(lái)插入數(shù)據(jù)。
- SQL> INSERT INTO t (empno, sal,comm) VALUES (10, 1500 , 500);
- 1 row created.
然后可以查詢虛擬列的值:
- SQL> select * from emp;
- EMPNO SAL COMM SAl_PACK
- ----- ------ ----- --------
- 10 1500 500 2000
- 1 row selected.
表達(dá)式是在查詢的時(shí)候即時(shí)計(jì)算的,然后輸出上述的結(jié)果。
虛擬列的索引和約束
索引和約束同樣可以應(yīng)用在虛擬列上。我們可使用如下SQL語(yǔ)句來(lái)創(chuàng)建索引:
- SQL> create index sal_pack_idx on emp(sal_pack);
- Index Created.
我們也可以為虛擬列創(chuàng)建外鍵。
使用 PLSQL 函數(shù)來(lái)處理虛擬列
虛擬列的定義可使用 PLSQL 函數(shù),但要求該函數(shù)必須是確定的:
- CREATE OR REPLACE FUNCTION sum_num (in_num1 NUMBER, in_num2 NUMBER)
- RETURN NUMBER DETERMINISTIC
- AS
- BEGIN
- RETURN in_num1 + in_num2;
- END;
然后可以在虛擬列中使用上述函數(shù):
- SQL>ALTER TABLE emp ADD sal_pack_temp GENERATED ALWAYS AS ( sum_num(SAL,COMM) ):
- Table Altered
虛擬列的注釋
為虛擬列創(chuàng)建注釋的方法:
- SQL> COMMENT ON COLUMN emp.sal_pack IS 'Virtual column [sal+ comm]';
- Comment created.
上述例子看來(lái)虛擬列的功能比視圖本身要簡(jiǎn)單很多。
希望這對(duì)你也有用。
原文鏈接:http://www.oschina.net/question/12_52437
【編輯推薦】