Oracle 11g 的新特性 - 虛擬列

jopen 12年前發布 | 21K 次閱讀 Oracle

今天我將為大家解釋 Oracle 11g 數據庫的新特性 —— 虛擬列

介紹

在老的 Oracle 版本,當我們需要使用表達式或者一些計算公式時,我們會創建數據庫視圖,如果我們需要在這個視圖上使用索引,我們會創建基于函數的索引。

現在 Oracle 11g 允許我們直接在表上使用虛擬列來存儲表達式。

來看一個簡單的例子:

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 是由一個簡單的表達式創建的,使用的關鍵字有 VIRTUAL(不過這個關鍵字是可選的),該字段的值是由 COMM 這個字段通過表達式計算而來的。

虛擬列的值是不存儲在磁盤的,它們是在查詢時根據定義的表達式臨時計算的。

我們不能往虛擬列中插入數據:
SQL> INSERT INTO emp VALUES (10, 1500, 500,2000);

ERROR at line 1:
ORA-54013: INSERT operation disallowed on virtual columns
我們也不能隱式的添加數據到虛擬列:
SQL> INSERT INTO t VALUES (10, 1500, 500);
            *
ERROR at line 1:
ORA-00947: not enough values 
我們只能使用物理列來插入數據。
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.

表達式是在查詢的時候即時計算的,然后輸出上述的結果。

虛擬列的索引和約束

索引和約束同樣可以應用在虛擬列上。我們可使用如下SQL語句來創建索引:
SQL> create index sal_pack_idx on emp(sal_pack);
           Index Created.

我們也可以為虛擬列創建外鍵。

使用 PLSQL 函數來處理虛擬列

虛擬列的定義可使用 PLSQL 函數,但要求該函數必須是確定的:
CREATE OR REPLACE FUNCTION sum_num (in_num1 NUMBER, in_num2 NUMBER)
   RETURN NUMBER DETERMINISTIC
AS
BEGIN
   RETURN in_num1 + in_num2;
END;
然后可以在虛擬列中使用上述函數:
SQL>ALTER TABLE emp ADD sal_pack_temp GENERATED ALWAYS AS ( sum_num(SAL,COMM) ):
Table Altered
虛擬列的注釋

為虛擬列創建注釋的方法:
SQL> COMMENT ON COLUMN emp.sal_pack IS 'Virtual column [sal+ comm]';
Comment created.

上述例子看來虛擬列的功能比視圖本身要簡單很多。

希望這對你也有用。

英文原文

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!