程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> DB2數據庫 >> DB2教程 >> DB2未使用索引的查找方案描述

DB2未使用索引的查找方案描述

編輯:DB2教程

此文章主要向大家描述的是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未使用索引,表和包的找出的介紹,望你能有所收獲。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved