DB2未使用索引找出的“竅門”是什么?
以下的文章主要介紹的是在DB2未使用索引,表和包的找出的找出,面的文章就是對(duì)其正確的操作內(nèi)容的描述,我們大家都知道表和包的找出的找出我們大家都知道在實(shí)際操作中LASTUSED列主要是告訴你索引在DB2數(shù)據(jù)庫(kù)中的最后一次訪問(wèn)時(shí)間。
但這個(gè)方法并不能保證百分之百返回準(zhǔn)確的值。
因?yàn)镈B2也會(huì)將更新這一列的時(shí)間當(dāng)作訪問(wèn)時(shí)間,但你可以使用db2pd工具準(zhǔn)確地獲得自數(shù)據(jù)庫(kù)啟動(dòng)以來(lái)DB2未使用索引的最后一次訪問(wèn)時(shí)間。
從DB2 9.7開(kāi)始,你可以使用下面的查詢檢查DB2中未使用的索引:
- SELECT INDSCHEMA, INDNAME, TABNAME FROM SYSCAT.INDEXES WHERE LASTUSED = '01/01/0001';
 
LASTUSED列告訴你索引在DB2中的最后一次訪問(wèn)時(shí)間,但這個(gè)方法并不能保證百分之百返回準(zhǔn)確的值,因?yàn)镈B2也會(huì)將更新這一列的時(shí)間當(dāng)作訪問(wèn)時(shí)間,但你可以使用db2pd工具準(zhǔn)確地獲得自數(shù)據(jù)庫(kù)啟動(dòng)以來(lái)索引的最后一次訪問(wèn)時(shí)間。
這個(gè)查詢只能工作在DB2 9.7或更高版本,但db2pd可以用于其它版本,在SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中都已經(jīng)增加了一列LASTUSED,因此從DB2 9.7開(kāi)始,你可以輕松查詢出未使用的DB2未使用索引,表和包。
- $ db2pd -d sample -tcbstats index
 
當(dāng)你在SAMPLE數(shù)據(jù)庫(kù)上運(yùn)行db2pd工具時(shí),使用tcbstats選項(xiàng),將參數(shù)index傳給它,你將會(huì)看到一串很長(zhǎng)的輸出內(nèi)容,當(dāng)你查看TCB Index信息時(shí),你需要查找SCANS列,你必須通過(guò)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
 
上面的輸出為了簡(jiǎn)潔美觀,我做了剪裁,DB2未使用索引名關(guān)聯(lián)IID,并使用Scans=0查找索引。
如果你的數(shù)據(jù)庫(kù)運(yùn)行了有一個(gè)月,你可以運(yùn)行db2pd工具找出有一個(gè)月都未曾使用過(guò)的索引。當(dāng)你運(yùn)行db2pd工具且數(shù)據(jù)庫(kù)處于活動(dòng)狀態(tài)時(shí),所有這些信息存在的時(shí)間都是非常短暫的,但SYSCAT.TABLES,SYSCAT.INDEXES和SYSCAT.PACKAGES表中LASTUSED列的信息是持久存儲(chǔ)的,通過(guò)它,你可以找出對(duì)象的最后訪問(wèn)時(shí)間,請(qǐng)記住DB2 for z/OS很久以前就有這個(gè)功能了,DB2 LUW現(xiàn)在也有這個(gè)功能了。
【編輯推薦】















 
 
 
 
 
 
 