假如聚簇因子过大,那么重建索引可能会有好处,聚簇因子应该接近块的数量,而非行的数量。 本文来自织梦
B-tree索引: 内容来自dedecms
·索引会随着时间的增加而变的不平衡;
·删除的索引空间不会被重用; dedecms.com
·随着索引层数的增加,索引将会变得无效并需要重建; copyright dedecms
·聚簇因子差,索引需要重建; 织梦好,好织梦
·为了提高性能,索引需要经常重建; 内容来自dedecms
索引基础 织梦好,好织梦
·一个更新由一个删除和一个插入组成;
织梦好,好织梦
·页块由索引条目(row header(2/3B)|length(1B)|indexed data value(nB)|length(1B)|RowID(6B))和相应的rowid组成; copyright dedecms
·每个页块包含两个指针分别前面的页块和后面页块; 织梦内容管理系统
Treedump
alter session set events ‘immediate trace name treedump level index_object_id’;
----- begin tree dump
branch: 0x424362 4342626 (0: nrow: 2, level: 1)
leaf: 0x424363 4342627 (-1: nrow: 540 rrow: 540)
leaf: 0x424364 4342628 (0: nrow: 461 rrow: 461)
----- end tree dump
以上dump包含的信息如下: 本文来自织梦
块类型:branch(分支块);leaf(页块); 织梦好,好织梦
块地址:0x424362 4342626; copyright dedecms
nrow:索引条目的数量; 本文来自织梦
rrow:当前块中的索引条目数量;
level:分支块等级(页块隐示为0);
Block Dump
alter system dump datafile X block X;
alter system dump datafile X block min X1 block max X2
Start dump data blocks tsn: 0 file#: 1 minblk 148538 maxblk 148538
buffer tsn: 0 rdba: 0x0042443a (1/148538)
scn: 0x0000.00162a95 seq: 0x01 flg: 0x04 tail: 0x2a950601
frmt: 0x02 chkval: 0x8b5c type: 0x06=trans data
Block header dump: 0x0042443a
Object id on Block? Y
seg/obj: 0xd1fe csc: 0x00.162a95 itc: 2 flg: O typ: 2 - INDEX
fsl: 0 fnx: 0x42443b ver: 0x01
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0x0005.02a.00000332 0x008005cb.020e.01 CB-- 0 scn 0x0000.00162a92
0x02 0x0008.011.00000346 0x008002e6.0163.03 C--- 0 scn 0x0000.00162a93 dedecms.com
该dump包含的信息如下:
rdba:分支块的相对数据库块地址(文件号/块号);
内容来自dedecms
scn:块最后改变的SCN号;
内容来自dedecms
type:块类型; 内容来自dedecms
seq:块改变的数量; 织梦内容管理系统
seg/obj: 16进制对象ID; 本文来自织梦
typ:段类型;
Itl:相关的事务槽(页块默认为2),包括槽ID,事务ID,撤销块地址,标记,锁信息,和事务SCN; 本文来自织梦
通过rba确定数据文件号和块号:
dedecms.com
select DBMS_UTILITY.DATA_BLOCK_ADDRESS_FILE(rba),
DBMS_UTILITY.DATA_BLOCK_ADDRESS_BLOCK(rba)
from dual;
织梦内容管理系统
通用的索引块头 copyright dedecms
header address 153168988=0x9212c5c
kdxcolev 0
KDXCOLEV Flags = - - -
kdxcolok 1
kdxcoopc 0x89: opcode=9: iot flags=--- is converted=Y
kdxconco 2 copyright dedecms
kdxcosdc 2
kdxconro 254
kdxcofbo 544=0x220
kdxcofeo 4482=0x1182
kdxcoavs 3938
kdxcolev:索引级别(0代表页块);
kdxcolok:标示结构块事块是否发生;
kdxcoopc:内部操作码;
kdxconco:索引列数量,包括ROWID;
kdxcosdc:块中索引结构改变的数量;
kdxconro:索引条目的数量,不包括kdxbrlmc指针;
kdxcofbo:块中空闲空间的开始位置;
kdxcofeo:块中空闲空间的结束位置;
kdxcoavs:块中的可用空间数量(kdxcofbo-kdxcofeo); 本文来自织梦
分支头区域 织梦内容管理系统
kdxbrlmc 8388627=0x800013
kdxbrsno 92
kdxbrbksz 8060
kdxbrlmc:如果索引值小于第一个值(row#0),则为该索引值所在的块地址;
kdxbrsno:最后更改的索引条目;
kdxbrbksz:可使用的块空间;
织梦好,好织梦


