Oracle SecureFile的功能第3/4頁(yè)
COMMIT;
END;
/
EXEC DBMS_STATS.gather_table_stats(USER, 'nocompress_tab');
EXEC DBMS_STATS.gather_table_stats(USER, 'compress_tab');
COLUMN segment_name FORMAT A30
SELECT segment_name, bytes
FROM user_segments
WHERE segment_name IN ('COMPRESS_LOB', 'NOCOMPRESS_LOB');
SEGMENT_NAME BYTES
------------------------------ ----------
COMPRESS_LOB 131072
NOCOMPRESS_LOB 71565312
2 rows selected.
SQL>
我們可以看到壓縮的LOB段比沒(méi)有壓縮的LOB段明顯要小得多,空間節(jié)約的程度依賴于LOB段數(shù)據(jù)的存儲(chǔ)類型。
可以使用ALTER TABLE命令重新設(shè)置壓縮模式。
ALTER TABLE compress_tab MODIFY LOB(clob_data) ( NOCOMPRESS ); EXEC DBMS_STATS.gather_table_stats(USER, 'compress_tab'); COLUMN segment_name FORMAT A30 SELECT segment_name, bytes FROM user_segments WHERE segment_name IN ('COMPRESS_LOB', 'NOCOMPRESS_LOB'); SEGMENT_NAME BYTES ------------------------------ ---------- COMPRESS_LOB 76808192 NOCOMPRESS_LOB 71630848 2 rows selected. SQL> |
LOB加密
SecureFile LOB的加密功能依賴于錢(qián)夾或硬件安全模型(HSM)掌管加密密鑰,錢(qián)夾設(shè)置與透明數(shù)據(jù)加密(TDE)和表空間加密描述的一樣,因此在嘗試下面的例子前先完成那兩個(gè)實(shí)驗(yàn)。
SecureFile的ENCRYPT選項(xiàng)執(zhí)行塊級(jí)別的LOB內(nèi)容加密,一個(gè)可選的USING子句定義了使用哪種加密算法(3DES168, AES128, AES192, 或AES256),默認(rèn)使用AES192算法,NO SALT選項(xiàng)對(duì)于SecureFile加密不可用,加密是應(yīng)用在每一列上的,因此它會(huì)影響所有使用LOB的分區(qū),DECRPT選項(xiàng)用于明確地阻止加密,下面的例子顯示了使用加密的SecureFile LOB數(shù)據(jù)類型創(chuàng)建表。
CREATE TABLE encrypt_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS SECUREFILE encrypt_lob( ENCRYPT USING 'AES256' ); |
ALTER TABLE命令可以用于加密或解密現(xiàn)有的列,要切換加密算法你必須使用REKEY選項(xiàng)。
ALTER TABLE encrypt_tab MODIFY ( clob_data CLOB DECRYPT ); ALTER TABLE encrypt_tab MODIFY ( clob_data CLOB ENCRYPT USING '3DES168' ); ALTER TABLE encrypt_tab REKEY USING 'AES192'; |
加密是不受原來(lái)的導(dǎo)入導(dǎo)出工具或表空間傳輸支持的,因此必須使用數(shù)據(jù)泵導(dǎo)入導(dǎo)出工具來(lái)傳輸數(shù)據(jù)。
LOB緩存和日志
BasicFile和SecureFile LOB共享了部分基礎(chǔ)的緩存和日志選項(xiàng),常見(jiàn)的緩存選項(xiàng)有:
◆CACHE - LOB數(shù)據(jù)被放在緩沖區(qū)中。
◆CACHE READES - 僅讀取LOB數(shù)據(jù)過(guò)程中它放在緩沖區(qū)中,寫(xiě)操作時(shí)不放進(jìn)去。
◆NOCACHE - LOB數(shù)據(jù)不放在緩沖區(qū)中,這是BasicFile和SecureFile LOB的默認(rèn)值。
基本的日志選項(xiàng)有:
◆LOGGING - 創(chuàng)建和修改LOB時(shí)產(chǎn)生完全重做日志,這是默認(rèn)設(shè)置。
◆NOLOGGING - 操作不記錄在重做日志中,因此不能恢復(fù),在首次創(chuàng)建和巨大的載入過(guò)程中有用。
而且,SecureFile LOB還有一個(gè)日志選項(xiàng)FILESYSTEM_LIKE_LOGGING,只記錄元數(shù)據(jù),在出現(xiàn)故障后仍然允許段的恢復(fù)。
CACHE選項(xiàng)意味著LOGGING,因此你不能將CACHE與NOLOGGING或FILESYSTEM_LIKE_LOGGING合在一起使用。
下面的代碼顯示了一個(gè)在表創(chuàng)建過(guò)程中和創(chuàng)建后明確設(shè)置了緩存和日志選項(xiàng)的例子。
CREATE TABLE caching_and_logging_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS SECUREFILE( NOCACHE FILESYSTEM_LIKE_LOGGING ); ALTER TABLE caching_and_logging_tab MODIFY LOB(clob_data) ( CACHE ); PL/SQL API |
相關(guān)文章
Oracle基礎(chǔ)多條sql執(zhí)行在中間的語(yǔ)句出現(xiàn)錯(cuò)誤時(shí)的控制方式
今天小編就為大家分享一篇關(guān)于Oracle基礎(chǔ)多條sql執(zhí)行在中間的語(yǔ)句出現(xiàn)錯(cuò)誤時(shí)的控制方式,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12
Oracle EBS工具選項(xiàng):關(guān)閉其他表單修改方法
這篇文章主要介紹了Oracle EBS工具選項(xiàng)關(guān)閉其他表單修改方法,包括通過(guò)SQL語(yǔ)句永久打開(kāi)或關(guān)閉這個(gè)選項(xiàng)的方法,需要的朋友可以了解下。2017-09-09
oracle 存儲(chǔ)過(guò)程和觸發(fā)器復(fù)制數(shù)據(jù)
oracle 存儲(chǔ)過(guò)程和觸發(fā)器復(fù)制數(shù)據(jù)的代碼,需要的朋友可以參考下。2009-11-11
oracle關(guān)聯(lián)查詢報(bào)invalid number錯(cuò)誤的解決方法
這篇文章主要介紹了oracle關(guān)聯(lián)查詢報(bào)invalid number錯(cuò)誤的解決方法,文中通過(guò)代碼示例和圖文結(jié)合的方式講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-09-09
Oracle11g數(shù)據(jù)庫(kù)win8.1系統(tǒng)安裝配置圖文教程
這篇文章主要介紹了 Oracle11g數(shù)據(jù)庫(kù)win8.1系統(tǒng)安裝配置圖文教程的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
oracle 動(dòng)態(tài)AdvStringGrid完美示例 (AdvStringGrid使用技巧/Cells)
本方法實(shí)現(xiàn)用常量和常量數(shù)組完美創(chuàng)建和控制動(dòng)態(tài)TAdvStringGrid。2009-06-06

