DB2未使用索引找出的“窍门”是什么?

数据库
以下的文章是介绍DB2未使用索引,表和包的找出的找出,以下就是相关内容的详细介绍,如果你对这一新开发的技术,心存好奇的话,以下的文章将会揭开它的神秘面纱。

以下的文章主要介绍的是在DB2未使用索引,表和包的找出的找出,面的文章就是对其正确的操作内容的描述,我们大家都知道表和包的找出的找出我们大家都知道在实际操作中LASTUSED列主要是告诉你索引在DB2数据库中的最后一次访问时间。

但这个方法并不能保证百分之百返回准确的值。

因为DB2也会将更新这一列的时间当作访问时间,但你可以使用db2pd工具准确地获得自数据库启动以来DB2未使用索引的最后一次访问时间。

 

从DB2 9.7开始,你可以使用下面的查询检查DB2中未使用的索引:

 

 

  1. 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未使用索引,表和包。

 

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

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

 

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

【编辑推荐】

  1. DB2提高IMPORT命令性能的2种操作方案
  2. DB2快照函数如何正确理解?
  3. DB2 9.5的数据库内存保护,轻松掌握!
  4. DB2建立数据库分区要用的命令有哪些?
  5. IBM DB2数据库中如何正确进行包的重绑定?
责任编辑:佚名 来源: C1G军火库
相关推荐

2010-07-27 10:17:14

DB2未使用索引

2010-08-04 15:00:06

DB2未使用索引

2010-03-03 10:03:09

DB2DBA

2010-08-18 13:29:11

DB2存储过程

2010-11-03 16:01:31

DB2索引的语法

2010-08-05 15:48:14

DB2强制优化器

2010-07-30 09:57:31

2010-09-07 17:36:37

DB2索引设计准则

2010-11-02 11:22:06

DB2索引类型

2010-11-02 11:36:10

DB2索引创建

2010-11-04 15:34:20

DB2索引优化

2010-08-10 10:01:39

DB2数据库备份

2010-08-02 14:50:41

DB2数据库

2010-09-06 09:05:25

DB2数据库

2010-09-06 10:00:00

DB2数据库

2010-08-05 15:32:44

重定向恢复DB2数据库

2010-09-30 16:00:40

DB2动态SQL

2010-11-02 11:30:09

DB2索引结构

2010-09-30 13:27:09

DB2游标

2010-08-02 18:09:15

DB2实例无法启动
点赞
收藏

51CTO技术栈公众号