DBA该如何在DB2中找出未使用索引,表和包

原创
数据库 数据库运维
本文将为大家讲述的是DB2 9.7中找出未使用的索引,表和包的一些简单方法,这样的方法能让DBA们的工作更加简便。

【51CTO经典译文】从DB2 9.7开始,你可以使用下面的查询检查DB2中未使用的索引:

  1. SELECT INDSCHEMA, INDNAME, TABNAME   
  2.   FROM SYSCAT.INDEXES  
  3. WHERE  LASTUSED = '01/01/0001'

LASTUSED列告诉你索引在DB2中的***一次访问时间,但这个方法并不能保证***返回准确的值,因为DB2也会将更新这一列的时间当作访问时间,但你可以使用db2pd工具准确地获得自数据库启动以来索引的***一次访问时间。

这个查询只能工作在DB2 9.7或更高版本,但db2pd可以用于其它版本,在SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中都已经增加了一列LASTUSED,因此从DB2 9.7开始,你可以轻松查询出未使用的索引,表和包。

  1. $ db2pd -d sample -tcbstats index 

当你在SAMPLE数据库上运行db2pd工具时,使用tcbstats选项,将参数index传给它,你将会看到一串很长的输出内容,当你查看TCB Index信息时,你需要查找SCANS列,你必须通过catalog表相互关联Index ID(IID)和索引名。

  1. Database Partition 0 -- Database SAMPLE -- Active -- Up 0 days 00:09:45  
  2.  
  3. TCB Table Information:  
  4. Address    TbspaceID TableID PartID MasterTbs MasterTab TableName  
  5. 0x7C6EF8A0 0         1       n/a    0         1         SYSBOOT    
  6. 0x7A0AC6A0 2         -1      n/a    2         -1        INTERNAL   
  7.  
  8. TCB Table Stats:  
  9. Address    TableName          Scans      UDI        RTSUDI  
  10. 0x7C6EF8A0 SYSBOOT            1          0          0       
  11. 0x7A0AC6A0 INTERNAL           0          0          0       
  12.  
  13. TCB Index Information:  
  14. Address    InxTbspace ObjectID TbspaceID TableID MasterTbs   
  15. 0x7A0ABDA8 0          5        0         5       0           
  16. 0x7A0ABDA8 0          5        0         5       0           
  17.  
  18. TCB Index Stats:  
  19. Address    TableName          IID   EmpPgDel   RootSplits BndrySplts PseuEmptPg Scans     
  20. 0x7A0ABDA8 SYSTABLES          9     0          0          0          0          0         
  21. 0x7A0ABDA8 SYSTABLES          8     0          0          0          0          0        

上面的输出为了简洁美观,我做了剪裁,索引名关联IID,并使用Scans=0查找索引。

如果你的数据库运行了有一个月,你可以运行db2pd工具找出有一个月都未曾使用过的索引。当你运行db2pd工具且数据库处于活动状态时,所有这些信息存在的时间都是非常短暂的,但SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中LASTUSED列的信息是持久存储的,通过它,你可以找出对象的***访问时间,请记住DB2 for z/OS很久以前就有这个功能了,DB2 LUW现在也有这个功能了。

原文出处:http://www.db2ude.com/?q=node/127

原文名:Unused indexes, tables and packages in DB2

【编辑推荐】

  1. 在DB2中正确导出LOB数据
  2. DB2外部文件格式浅析
  3. DB2数据库设计的三个建议
  4. 解析DB2与非DB2数据库之间远程复制
  5. DB2数据库基本操作指令30条
责任编辑:彭凡 来源: 51CTO
相关推荐

2010-07-27 10:17:14

DB2未使用索引

2010-08-06 17:52:17

DB2未使用索引

2010-09-06 09:05:25

DB2数据库

2010-08-04 15:00:06

DB2未使用索引

2011-05-17 09:32:25

DB2

2009-04-16 15:38:18

DB2IMPORT性能

2009-04-10 08:56:16

DB2Insert性能

2010-08-26 14:01:59

DB2插入特殊字符

2010-11-03 15:49:32

DB2删除表

2010-09-01 09:32:08

DB2恢复

2010-09-07 17:36:37

DB2索引设计准则

2010-11-02 11:22:06

DB2索引类型

2010-11-02 11:36:10

DB2索引创建

2010-09-01 11:39:17

DB2聚集目标表

2010-08-16 17:07:43

DB2 trc

2010-08-25 13:46:00

DB2函数日期

2010-11-01 11:13:57

DB2表管理

2010-11-01 12:11:43

DB2表空间

2010-09-30 09:42:22

DB2删除数据

2013-01-04 10:42:06

IBMdW
点赞
收藏

51CTO技术栈公众号