|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
因此我们看到,这些信息足够让我们对单个操作实现“逆操作”。创立
创立表时思索列的按次
创立一个表时表中列的按次在某些水平上对功能会有必定的影响.(表中的列无数据)
Oracle对行数据的存储布局ROWHEADER(行头)和COLUMNDATA(列数据).ROWHEADER存储的信息是一个FLAGBYTE,一个LOCKBYTE和COLUMN
COUNT.COLUMNDATA包括COLUMNLENGTH和COLUMNDATA
关于这些我们能够DUMP个表做一下测试
createtestasselect*fromdba_objects;
selectheader_file,header_blockfromdba_segmentswhereowner=TESTandsegment_name=TEST;
HEADER_FILEHEADER_BLOCK
---------------------------------------------------
131179
altersystemdumpdatafile13block1180
得出来的文件在UDUMP中.我们检察以下信息
block_row_dump:
tab0,row0,@0x1f20
tl:96fb:--H-FL--lb:0x0cc:13--------rowheader信息.
col0:[3]535953-------------------COLUMNDATA
fb:--H-FL--是FLAGBYTE.
fbFlagByte:
K=ClusterKey(FlagsmaychangemeaningifthisissettoshowHASHcluster)
C=Clustertablemember
H=Headpieceofrow
D=Deletedrow
F=Firstdatapiece
L=Lastdatapiece
P=Firstcolumncontinuesfrompreviouspiece
N=Lastcolumncontinuesinnextpiece
lb:0x0-----------LOCKBYTE,锁信息
cc:13------------COLUMNCOUNT
col0---------第一列
[3]-------------COLUMNLENGTH
535953---------实践数据
这里一些信息能够参考grassbell写的文章<<窃看Datablock的物理布局>>.对每个列,在每个列数据前都含有列长度.在做查询时,查询行中某个
列的值,Oracle起首做的是反省这些相干列的长度位.这个操纵对照快并且效力较高.可是假如重复频仍的如许子做仍是会带来功能方面的影响.
上面的例子中创立了一个有10列的表并拔出数据.
先设置DB_BLOCK_SIZE=2K(用参数设置,在这里设置为这个只是为了测试便利)
SQL>createtablesmall(
2n0number,
3n1number,
4n2number,
5n3number,
6n4number,
7n5number,
8n6number,
9n7number,
10n8number,
11n9number
12)pctfree0;
Tablecreated.
SQL>begin
2foriin1..78loop
3insertintosmallvalues(0,0,0,0,0,0,0,0,0,0);
4endloop;
5end;
6/
PL/SQLproceduresuccessfullycompleted.
SQL>settimingon
SQL>declare
2nnumber;
3begin
4foriin1..1000000loop
5selectsum(n0)intonfromsmall;
6endloop;
7end;
8/
PL/SQLproceduresuccessfullycompleted.
Elapsed:00:07:437.30
SQL>declare
2nnumber;
3begin
4foriin1..1000000loop
5selectsum(n9)intonfromsmall;
6endloop;
7end;
8/
PL/SQLproceduresuccessfullycompleted.
Elapsed:00:08:482.13
从下面的例子很分明能够看到在一个表中做查询时,查询的数据和列的属性都是一样的,可是所查的各位于第一列时查询速率比在第10快了差未几
10%.以是在建表的时分划定规矩就是依据使用将表中常常会见的列放眼前面.建表时一样平常都有一个PRIMARYKEY的列,像这类属性的列一样平常我们间接访
问的其实不多.以是我们一样平常不放在第一列.关于这个实在假如我们有注重到的话,Oracle自己字典内表也是如许子的.
descdba_objects看看.大概其他的表能够尝尝.
另有别的一个要思索的列的地位的就是列中含有较多的NULL值时所要放的地位.
Oracle存储NULL值时,一行中某个列存在NULL值,而这一列的前面的列中存在无数据(非NULL),则Oracle会分派1byte来寄存NULL.假如这一列的前面
没有列大概都是NULL值时.这一列和前面的NULL值Oracle都不做存储.列信息也不存储.这一点能够看以下例子.
SQL>createtablenull_order(
2column1number,
3column2number,
4column3number
5);
Tablecreated.
SQL>insertintonull_order(column2)values(0);
1rowcreated.
SQL>selectheader_file,header_blockfromdba_segments
2wheresegment_name=TESTandowner=TEST;
HEADER_FILEHEADER_BLOCK
-----------------------
350010
SQL>altersystemdumpdatafile3block50011;
Systemaltered.
然后检察DUMP出来的文件的相干信息
block_row_dump:
tab0,row0,@0x7b2
tl:6fb:--H-FL--lb:0x1cc:2
col0:*NULL*--------------第一列的NULL
col1:[1]80----------------第二列的值(前面没有了第三列的值)
end_of_block_dump
结论:创立一个表时,能够将我们常常会见到的列放在表的后面.一样平常很少间接SELECT出来的PRIMARYKEY列能够放到两头来.列中假如大概会含有
较多NULL值的列能够放在最初面.能够终合思索下面两点,依据体系的使用做响应操纵.
“数据行级锁定”的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT、LOCKINSHAREMODE、SELECT、FORUPDATE命令以及INSERT、UPDATE和DELETE命令。 |
|