此文章主要向大家描述的是DB2未使用索引,表和包的找出的实际操作步骤,如果你对DB2未使用索引,表和包的找出的实际操作步骤有兴趣的话,你就可以对以下的文章点击观看了。我们大家都知道LASTUSED列告诉你索引在DB2数据库中的***一次访问的具体时间。
但是这个方法并不能保证***返回准确的值,因为DB2也会将更新这一列的时间当作访问时间。但你可以使用db2pd工具准确地获得自数据库启动以来索引的***一次访问时间。
从DB2 9.7开始,你可以使用下面的查询检查DB2中未使用的索引:
SELECT INDSCHEMA, INDNAME, TABNAME FROM SYSCAT.INDEXES WHERE LASTUSED = '01/01/0001';
LASTUSED列告诉你索引在DB2中的***一次访问时间,但这个方法并不能保证***返回准确的值,因为DB2也会将更新这一列的时间当作访问时间,但你可以使用db2pd工具准确地获得自数据库启动以来索引的***一次访问时间。
这个查询只能工作在DB2 9.7或更高版本,但db2pd可以用于其它版本,在SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中都已经增加了一列LASTUSED,因此从DB2 9.7开始,你可以轻松查询出DB2未使用索引,表和包。
$ 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现在也有这个功能了。
以上的相关内容就是对如何在DB2未使用索引,表和包的找出的介绍,望你能有所收获。
以上的相关内容就是对DB2未使用索引,表和包的找出的介绍,望你能有所收获。
【编辑推荐】
- DB2 数据库表锁的模式的描述
- DB2数据库上正确建立database Partition很简单!
- 对IBM DB2商业智能软件的描述
- IBM DB2数据库产品的都有哪些市场表现?
- IBM DB2数据复制以及迁移,以实例讲述