研究解决CLOB字段IO问题的方法

本文介绍如何通过缓存表及LOB数据来提升数据库性能,包括普通表、LOB段和基于CLOB的对象缓存方法,并提供具体实现步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目前已经采取的做法,缓存该表
网上查到的做法

 一、对于普通表的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: 

 

Sql代码   收藏代码
  1. select decode(id,'10',lob_col,nullfrom tb  


2.给lob字段建立单独的表空间,并设定把CACHE 设定成reads提高读取速度。 
代码: 

Sql代码   收藏代码
  1. --创建表空间  
  2. CREATE TABLESPACE MONTANA DATAFILE 'montana.tbs' SIZE 500M;  
  3.   
  4.   
  5. --修改lob对象的表空间(STRINGDATA和OBJECTDATA是lob字段)  
  6. ALTER TABLE tb MOVE LOB (STRINGDATA,OBJECTDATA) STORE AS  
  7. (  
  8. TABLESPACE MONTANA  
  9. CACHE READS    
  10. )  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值