一、对于普通表的cache方法:
SQL> conn test/test 已连接。
SQL> alter table t1 storage (buffer_pool keep) cache;
表已更改。
查询普通表是否已经被cache:
SQL> select table_name,cache,buffer_pool from user_TABLES;
TABLE_NAME CACHE BUFFER_
------------------------------ --------
T1 Y KEEP
二、对于普通LOB类型的segment的cache方法
SQL> desc t2
名称 是否为空? 类型
----------------------------------------
ID NUMBER
C2 CLOB
SQL> alter table t2 modify lob(c2) (storage (buffer_pool keep) cache);
表已更改。
三、对基于CLOB类型的对象的cache方法
SQL> desc lob1
名称 是否为空? 类型
----------------------------------------- ID NUMBER
C1 XMLTYPE
SQL> alter table lob1 modify lob(c1.xmldata) (storage (buffer_pool keep) cache);表已更改。
那么,怎么测试lob segment是否被cache了呢?
1.检索lob字段的时候,按需去取lob字段,如果你不用,则给它设成null,比如我要id='10'的lob字段,那么sql:
- select decode(id,'10',lob_col,null) from tb
2.给lob字段建立单独的表空间,并设定把CACHE 设定成reads提高读取速度。
代码:
- --创建表空间
- CREATE TABLESPACE MONTANA DATAFILE 'montana.tbs' SIZE 500M;
- --修改lob对象的表空间(STRINGDATA和OBJECTDATA是lob字段)
- ALTER TABLE tb MOVE LOB (STRINGDATA,OBJECTDATA) STORE AS
- (
- TABLESPACE MONTANA
- CACHE READS
- )