日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Oracle11g的新特性:虛擬列

今天我將為大家解釋 Oracle 11g 數(shù)據(jù)庫(kù)的新特性 —— 虛擬列

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),磴口企業(yè)網(wǎng)站建設(shè),磴口品牌網(wǎng)站建設(shè),網(wǎng)站定制,磴口網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,磴口網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

介紹

在老的 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)單的例子:

 
 
 
  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 是由一個(gè)簡(jiǎn)單的表達(dá)式創(chuàng)建的,使用的關(guān)鍵字有 VIRTUAL(不過(guò)這個(gè)關(guān)鍵字是可選的),該字段的值是由 COMM 這個(gè)字段通過(guò)表達(dá)式計(jì)算而來(lái)的。

虛擬列的值是不存儲(chǔ)在磁盤的,它們是在查詢時(shí)根據(jù)定義的表達(dá)式臨時(shí)計(jì)算的。

我們不能往虛擬列中插入數(shù)據(jù):

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

我們也不能隱式的添加數(shù)據(jù)到虛擬列:

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

我們只能使用物理列來(lái)插入數(shù)據(jù)。

 
 
 
  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.

表達(dá)式是在查詢的時(shí)候即時(shí)計(jì)算的,然后輸出上述的結(jié)果。

虛擬列的索引和約束

索引和約束同樣可以應(yīng)用在虛擬列上。我們可使用如下SQL語(yǔ)句來(lái)創(chuàng)建索引:

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

我們也可以為虛擬列創(chuàng)建外鍵。

使用 PLSQL 函數(shù)來(lái)處理虛擬列

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

 
 
 
  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;

然后可以在虛擬列中使用上述函數(shù):

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

虛擬列的注釋

為虛擬列創(chuàng)建注釋的方法:

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

上述例子看來(lái)虛擬列的功能比視圖本身要簡(jiǎn)單很多。

希望這對(duì)你也有用。


分享名稱:Oracle11g的新特性:虛擬列
當(dāng)前網(wǎng)址:http://www.dlmjj.cn/article/dppjcic.html