Oracle SecureFile的功能第1/4頁
初始化參數(shù)
SecureFile功能在初始化參數(shù)COMPATIBLE設置我11.0.0.0.0或更高時可用。
DB_SECUREFILE初始化參數(shù)控制數(shù)據(jù)庫對LOB存儲格式的默認行為,允許的值有:
◆ALWAYS - 在ASSM表空間中的所有LOB對象以SecureFile LOB的格式創(chuàng)建,在非ASSM表空間中的所有LOB對象以BasicFile LOB的格式創(chuàng)建(除非明確地指出要以SecureFile格式創(chuàng)建),在沒有指定選項的情況下,BasicFile存儲格式選項被忽略,SecureFile默認存儲格式選項被使用。
◆ FORCE - 所有LOB對象都以SecureFile LOB格式創(chuàng)建,如果是在一個非ASSM表空間中創(chuàng)建LOB,會出現(xiàn)錯誤,在沒有指定選項的情況下,BasicFile存儲格式選項被忽略,SecureFile默認存儲格式選項被使用。
◆PERMITTED - 默認設置,當使用了SECUREFILE關鍵字時它允許SecureFile LOB存儲格式,默認存儲方法是BASICFILE。
◆NEVER - 不允許創(chuàng)建SecureFile LOB對象。
◆IGNORE - 防止創(chuàng)建SecureFile LOB,使用SecureFile存儲選項時忽略所有錯誤。
這個參數(shù)是動態(tài)的,因此它可以使用ALTER SYSTEM命令設置。
SQL> ALTER SYSTEM SET db_securefile = 'FORCE'; System altered. SQL> ALTER SYSTEM SET db_securefile = 'PERMITTED'; System altered. SQL> |
下面的例子假設DB_SECUREFILE初始化參數(shù)設置為默認值PERMITTED。
創(chuàng)建SecureFile LOB
基礎
SecureFile LOB通過在LOB存儲子句后添加SECUREFILE關鍵字來創(chuàng)建,下面的代碼顯示創(chuàng)建了兩個表,第一個使用的是原來的存儲格式,第二個使用的是SecureFile存儲格式。
CREATE TABLE bf_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS BASICFILE; INSERT INTO bf_tab VALUES (1, 'My CLOB data'); COMMIT; CREATE TABLE sf_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS SECUREFILE; INSERT INTO sf_tab VALUES (1, 'My CLOB data'); COMMIT; |
LOB重復消除
SecureFile的DEDUPLICATE選項允許在表或分區(qū)一級上的一個LOB內消除重復數(shù)據(jù),正如你預料的那樣,這個技術與預防重寫導致系統(tǒng)開銷增大,KEEP_DUPLICATE選項明確地阻止重復消除,下面的例子對比了普通的SecureFile和重復消除SecureFile的空間使用情況。
CREATE TABLE keep_duplicates_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS SECUREFILE keepdup_lob( KEEP_DUPLICATES ); CREATE TABLE deduplicate_tab ( id NUMBER, clob_data CLOB ) LOB(clob_data) STORE AS SECUREFILE dedup_lob ( DEDUPLICATE ); DECLARE l_clob CLOB := RPAD('X', 10000, 'X'); BEGIN FOR i IN 1 .. 1000 LOOP INSERT INTO keep_duplicates_tab VALUES (i, l_clob); END LOOP; COMMIT; FOR i IN 1 .. 1000 LOOP INSERT INTO deduplicate_tab VALUES (i, l_clob); END LOOP; COMMIT; END; / EXEC DBMS_STATS.gather_table_stats(USER, 'keep_duplicates_tab'); EXEC DBMS_STATS.gather_table_stats(USER, 'deduplicate_tab'); COLUMN segment_name FORMAT A30 SELECT segment_name, bytes FROM user_segments WHERE segment_name IN ('KEEPDUP_LOB', 'DEDUP_LOB'); SEGMENT_NAME BYTES ------------------------------ ---------- DEDUP_LOB 262144 KEEPDUP_LOB 19267584 2 rows selected. SQL> |
注意重復消除段要小很多,空間節(jié)約依賴于LOB段內的重復程度,重復模式可以使用ALTER TABLE命令進行重新設置。
相關文章
Oracle基礎多條sql執(zhí)行在中間的語句出現(xiàn)錯誤時的控制方式
今天小編就為大家分享一篇關于Oracle基礎多條sql執(zhí)行在中間的語句出現(xiàn)錯誤時的控制方式,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12
oracle 存儲過程和觸發(fā)器復制數(shù)據(jù)
oracle 存儲過程和觸發(fā)器復制數(shù)據(jù)的代碼,需要的朋友可以參考下。2009-11-11
oracle關聯(lián)查詢報invalid number錯誤的解決方法
這篇文章主要介紹了oracle關聯(lián)查詢報invalid number錯誤的解決方法,文中通過代碼示例和圖文結合的方式講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2024-09-09
Oracle11g數(shù)據(jù)庫win8.1系統(tǒng)安裝配置圖文教程
這篇文章主要介紹了 Oracle11g數(shù)據(jù)庫win8.1系統(tǒng)安裝配置圖文教程的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07
oracle 動態(tài)AdvStringGrid完美示例 (AdvStringGrid使用技巧/Cells)
本方法實現(xiàn)用常量和常量數(shù)組完美創(chuàng)建和控制動態(tài)TAdvStringGrid。2009-06-06

