程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle 11g的新特性:虛擬列

Oracle 11g的新特性:虛擬列

編輯:Oracle數據庫基礎

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

介紹

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

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

來看一個簡單的例子:

  1. CREATE TABLE EMP
  2. (
  3. EMPNO NUMBER(6),
  4. SAL NUMBER(8,2),
  5. COMM NUMBER(8,2),
  6. SAL_PACK GENERATED ALWAYS AS ( SAL + NVL(COMM,0) ) VIRTUAL
  7. );

上述建的虛擬列 SAL_PACK 是由一個簡單的表達式創建的,使用的關鍵字有 VIRTUAL(不過這個關鍵字是可選的),該字段的值是由 COMM 這個字段通過表達式計算而來的。

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

我們不能往虛擬列中插入數據:

  1. SQL> INSERT INTO emp VALUES (10, 1500, 500,2000);
  2. ERROR at line 1:
  3. ORA-54013: INSERT Operation disallowed on virtual columns

我們也不能隱式的添加數據到虛擬列:

  1. SQL> INSERT INTO t VALUES (10, 1500, 500);
  2. *
  3. ERROR at line 1:
  4. ORA-00947: not enough values

我們只能使用物理列來插入數據。

  1. SQL> INSERT INTO t (empno, sal,comm) VALUES (10, 1500 , 500);
  2. 1 row created.

然後可以查詢虛擬列的值:

  1. SQL> select * from emp;
  2. EMPNO SAL COMM SAl_PACK
  3. ----- ------ ----- --------
  4. 10 1500 500 2000
  5. 1 row selected.

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

虛擬列的索引和約束

索引和約束同樣可以應用在虛擬列上。我們可使用如下SQL語句來創建索引:

  1. SQL> create index sal_pack_idx on emp(sal_pack);
  2. Index Created.

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

使用 PLSQL 函數來處理虛擬列

虛擬列的定義可使用 PLSQL 函數,但要求該函數必須是確定的:

  1. CREATE OR REPLACE FUNCTION sum_num (in_num1 NUMBER, in_num2 NUMBER)
  2. RETURN NUMBER DETERMINISTIC
  3. AS
  4. BEGIN
  5. RETURN in_num1 + in_num2;
  6. END;

然後可以在虛擬列中使用上述函數:

  1. SQL>ALTER TABLE emp ADD sal_pack_temp GENERATED ALWAYS AS ( sum_num(SAL,COMM) ):
  2. Table Altered

虛擬列的注釋

為虛擬列創建注釋的方法:

  1. SQL> COMMENT ON COLUMN emp.sal_pack IS 'Virtual column [sal+ comm]';
  2. Comment created.

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

希望這對你也有用。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved