新聞中心
我們今天主要向大家講述的是在DB2數(shù)據(jù)庫中正確找出未使用索引,表以及包的實(shí)際操作流程,以及其在實(shí)際操作中所涉及到的實(shí)際操作代碼以及相關(guān)操作細(xì)節(jié)的描述,以下就是文章的主要內(nèi)容講述。

創(chuàng)新互聯(lián)建站專注于中大型企業(yè)的網(wǎng)站設(shè)計制作、網(wǎng)站設(shè)計和網(wǎng)站改版、網(wǎng)站營銷服務(wù),追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術(shù)與技術(shù)開發(fā)的融合,累計客戶上千家,服務(wù)滿意度達(dá)97%。幫助廣大客戶順利對接上互聯(lián)網(wǎng)浪潮,準(zhǔn)確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運(yùn)用,我們將一直專注成都品牌網(wǎng)站建設(shè)和互聯(lián)網(wǎng)程序開發(fā),在前進(jìn)的路上,與客戶一起成長!
LASTUSED列告訴你索引在DB2中的最后一次訪問時間,但這個方法并不能保證百分之百返回準(zhǔn)確的值,因為DB2也會將更新這一列的時間當(dāng)作訪問時間,但你可以使用db2pd工具準(zhǔn)確地獲得自DB2數(shù)據(jù)庫啟動以來索引的最后一次訪問時間。
從DB2 9.7開始,你可以使用下面的查詢檢查DB2中未使用的索引:
- SELECT INDSCHEMA, INDNAME, TABNAME FROM SYSCAT.INDEXES WHERE LASTUSED = '01/01/0001';
LASTUSED列告訴你索引在DB2中的最后一次訪問時間,但這個方法并不能保證百分之百返回準(zhǔn)確的值,因為DB2也會將更新這一列的時間當(dāng)作訪問時間,但你可以使用db2pd工具準(zhǔn)確地獲得自數(shù)據(jù)庫啟動以來索引的最后一次訪問時間。
這個查詢只能工作在DB2 9.7或更高版本,但db2pd可以用于其它版本,在SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中都已經(jīng)增加了一列LASTUSED,因此從DB2 9.7開始,你可以輕松查詢出未使用的索引,表和包。
$ db2pd -d sample -tcbstats index
當(dāng)你在SAMPLE數(shù)據(jù)庫上運(yùn)行db2pd工具時,使用tcbstats選項,將參數(shù)index傳給它,你將會看到一串很長的輸出內(nèi)容,當(dāng)你查看TCB Index信息時,你需要查找SCANS列,你必須通過catalog表相互關(guān)聯(lián)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
上面的輸出為了簡潔美觀,我做了剪裁,索引名關(guān)聯(lián)IID,并使用Scans=0查找索引。
如果你的DB2數(shù)據(jù)庫運(yùn)行了有一個月,你可以運(yùn)行db2pd工具找出有一個月都未曾使用過的索引。當(dāng)你運(yùn)行db2pd工具且數(shù)據(jù)庫處于活動狀態(tài)時,所有這些信息存在的時間都是非常短暫的,但SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中LASTUSED列的信息是持久存儲的,通過它,你可以找出對象的最后訪問時間,請記住DB2 for z/OS很久以前就有這個功能了,DB2 LUW現(xiàn)在也有這個功能了。
新聞標(biāo)題:DB2數(shù)據(jù)庫中對未使用索引,表與包的正確選出步驟
鏈接分享:http://m.5511xx.com/article/cdssesj.html


咨詢
建站咨詢
