注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

无线时代辐射无穷

抓紧生宝宝,小心辐射

 
 
 

日志

 
 

Oracle 找出需要建立索引的表  

2010-01-20 11:06:37|  分类: oracle |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
本来应该建立索引而因为疏忽,或者考虑不周全而没有建立的情况,
至于什么时候需要建立索引网上的文章很多,在这里不做说明了,

select distinct sp.OBJECT_NAME,round(ds.bytes/1024/1024,2) MB,num_rows,last_analyzed
from v$sql_plan sp ,v$sqlarea sq,dba_segments ds,dba_tables dt
where sq.ADDRESS=sp.ADDRESS
and ds.segment_name=sp.object_name
and dt.table_name=ds.segment_name
and sp.options='FULL'
and dt.owner='用户名'
and round(ds.bytes/1024/1024,2)>1
order by round(ds.bytes/1024/1024,2);

以上sql是:
通过定位到用户,找到在v$sql_plan里发生全表扫描的表。
并通过其他视图表(dba_tables,dba_segments)的关联,列出它的一些详细信息:大小,行数,分析时间。
我们可以再加一列,sq.sql_text把sql打印出来。
其中添加了一个条件是表的大小大于1M的表,一般情况下1M的表应该是1万行左右。(如果1M的表行数很少的话,那可能需要回收高水位线,可以参考我另外一篇文章合适需要回收表的高水位线)
小表的话我们不考虑,因为走全表扫描可能更快。
这个sql查询结果只做参考。具体问题还要具体分析。
当然这个是一个亡羊补牢的方法,我们在开发设计时,应该提起考虑好,那些列会用到索引,提起建立好,而不是出现性能问题在做。
  评论这张
 
阅读(536)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017