db2查询表的最后使用时间

在本月出账的过程中,出现表空间不足的情况。虽然在出账之前已清理过数据库中不用的表,但无奈只关心了其中一个,而忽略了另外一个,导致在跑大数据量的存储过程时出现空间不足。
出现此问题的解决办法是将目前库中已经不适用的表删除掉,已节省空间。
但在删除的过程中,要一个一个表去查找,很是麻烦。经查资料,发现有如下几种解决办法:
1、逐个看在需要清除的表空间中的表哪些是已经不用的,将此备份出来之后删除。
2、使用db2的系统表SYSCAT.TABLES中根据LASTUSED字段查询最后的使用时间。该字段是在v9.7版本之后才有的字段。不单单是表的最后使用时间,在在SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中都已经增加了一列LASTUSED 。而我们库是使用的v9.5,因此此方法可以在以后升级之后使用。
3、就是使用db2pd工具来查询表的insert update delete条数,通过这个也是可以判断出表的使用频率的。不过此方法也只能做一个参考了。
使用db2pd的具体方法是: db2pd -d sample -tcbstats index
当你在SAMPLE数据库上运行db2pd工具时,使用tcbstats选项,将参数index传给它,你将会看到一串很长的输出内容,当你查看TCB Index信息时,你需要查找SCANS列,你必须通过catalog表相互关联Index ID(IID)和索引名。
Database Partition 0 -- Database SAMPLE -- Active -- Up 0 days 00:09:45
TCB Table Information:
Address TbspaceID TableID PartID MasterTbs MasterTab TableName 0x7C6EF8A0 0 1 n/a 0 1 SYSBOOT 0x7A0AC6A0 2 -1 n/a 2 -1 INTERNAL

TCB Table Stats:
Address TableName Scans UDI RTSUDI 0x7C6EF8A0 SYSBOOT 1 0 0 0x7A0AC6A0 INTERNAL 0 0 0

TCB Index Information:
Address InxTbspace ObjectID TbspaceID TableID MasterTbs 0x7A0ABDA8 0 5 0 5 0 0x7A0ABDA8 0 5 0 5 0

TCB Index Stats:
Address TableName
IID EmpPgDel RootSplits BndrySplts PseuEmptPg Scans
0x7A0ABDA8 SYSTABLES
9 0 0 0 0 0
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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值