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

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

成都创新互联公司技术团队十多年来致力于为客户提供网站建设、成都做网站成都品牌网站建设网络营销推广、搜索引擎SEO优化等服务。经过多年发展,公司拥有经验丰富的技术团队,先后服务、推广了上千网站,包括各类中小企业、企事单位、高校等机构单位。

 
 
 
  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. TCB Table Information:
  3. Address    TbspaceID TableID PartID MasterTbs MasterTab TableName
  4. 0x7C6EF8A0 0         1       n/a    0         1         SYSBOOT  
  5. 0x7A0AC6A0 2         -1      n/a    2         -1        INTERNAL 
  6. TCB Table Stats:
  7. Address    TableName          Scans      UDI        RTSUDI
  8. 0x7C6EF8A0 SYSBOOT            1          0          0     
  9. 0x7A0AC6A0 INTERNAL           0          0          0     
  10. TCB Index Information:
  11. Address    InxTbspace ObjectID TbspaceID TableID MasterTbs 
  12. 0x7A0ABDA8 0          5        0         5       0         
  13. 0x7A0ABDA8 0          5        0         5       0         
  14. TCB Index Stats:
  15. Address    TableName          IID   EmpPgDel   RootSplits BndrySplts PseuEmptPg Scans   
  16. 0x7A0ABDA8 SYSTABLES          9     0          0          0          0          0       
  17. 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

网站名称:DBA该如何在DB2中找出未使用索引,表和包
文章位置:http://www.gawzjz.com/qtweb2/news6/7156.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联