合理设置segment的大小;
1)PCTFREE、PCTUSED使你能控制一个segment里所有数据块里free space的使用。
– Default 10
SELECT num_rows, blocks, empty_blocks as empty,avg_space, chain_cnt, avg_row_len FROM dba_tables WHERE owner ='NDLS' AND table_name='T_WH_SHIPPING_BILL';
• PCTUSED
Oracle性能优化之优化排序操作使用import/export工具:export数据;drop或truncate表;import数据。或者利用alter table tanle_name move命令去移动表的存储位置(此时需要重建索引)。
通过下列方法可以最小化block的访问次数:
4、block size
Oracle性能优化之应用优化使用更大的block size;紧密压缩行;阻止行镜像。后两者存在冲突,网页游戏私服大全,越多的行被压缩在一个block里,越容易产生镜像。
其中,upd : the average amount added by updates, in bytes。This is determined by subtracting the average row length of intercurrent average row length;
在full table scan中,oracle会读取high water mark以下的所有的数据块,所以high water mark以上的块也许会浪费存储空间,但不会降低性能。
4)Delete、update可以增加block的自由空间,但是释放出来的空间有可能是不连续的,oracle在下列情况下会对碎片进行整理:一个block有足够的自由空间容纳row piece,但是由于每个碎片都较小以至这个row piece不能存放在一个连续的section中。
– PCTUSED = 100 – PCTFREE – 100 × rows × (average row length) / blocksize
– Default 40
较小的block size的优点:极少block竞争;有利于较小的行和随机访问。缺点是存在相当高的成本,每个block的行数更少,可能需要读取更多的index块。
用analyize命令生成表统计,然后到dba_table查询相关信息。
Block size 在数据库创建的时候设定,不能被轻易改变,是读取数据文件时最小的IO单元,大小范围是2K-64K,应该设置成OS块的整数倍,小于或等于OS IO时能读取的存储区域。
5、PCTFREE、PCTUSED
Oracle性能优化经验分享之系统参数设置1、避免动态分配的缺陷
如果创建表的时候指定pctfree=20%,oracle会在这个表的data segment的每个block都保留20%的空间用于已有记录的更新。Block的已使用空间上升到整个block size的80%时,这个block将移出free list;在提交了delete、update之后,oracle server处理这条语句并检查对应block的已使用空间是否低于PCTUSED,如果是,则这个block放进free list。
Oracle性能优化之LockContention• PCTFREE
监控将要扩展的segment:
可以通过下列方法收回表中high water mark以上的块:
– PCTFREE = 100 × upd / (average row length)
Alter table_name deallocate unused;
rows : the number of rows to be deleted before free list maintenance occurs。
ANALYZE TABLE ndls.t_wh_shipping_bill COMPUTE STATISTICS;
average row length:在运行了analyize命令之后,这个值可以从dba_tables中的avg_row_len列中获得。
– Zero if no UPDATE activity
对于high water mark以下的块:
Oracle性能优化之Rollback(undo)Segment优化Oracle性能优化之诊断latch竞争
PCTFREE:一个数据块保留的用于块里已有记录的可能更新的自由空间占block size的最小比例。
记录在segment header block中,在segment创建的时候设定在segment的起始位置,当记录被插入的时候以5个block的增量增加,truncate可以重设high water mark的位置,但delete不能。
Oracle性能优化:数据库配置和IO问题
3)PCTFREE、PCTUSED的设定
Block size的选择影响系统的性能,在一个OLTP环境中,较小的block size更合适,而在DSS环境中,适宜选择较大的block size。
2)这两个参数的使用
2、high water mark
3、表统计
创建本地管理的表空间;
PCTUSED:在新记录被插入block里之前这个block可以用于存储行数据和其他信息的空间所占的最小比率。
【IT168 技术文档】
SELECT owner, table_name, blocks, empty_blocks FROM dba_tables WHERE empty_blocks / (blocks+empty_blocks) < .1;
– Set if rows deleted