oracle pct increase,oracle中PCTFREE INITRANS MAXTRANS STORAGE参数

本文详细解析了Oracle数据库中PCTFREE、INITRANS、MAXTRANS等存储参数的意义及作用,帮助理解如何合理设置这些参数以优化数据库性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.

PCTFREE

要形容一个 BLOCK 的运作,我们可以把一个 BLOCK 想成一个水杯。侍者把水倒入放在我们面前的水杯,要多满呢,我们要求他倒 9

分满好了,这时候 PCTFREE 代表着设定为 10 ,意思就是说,当 BLOCK 使用到达 90% 的时候,就不可以在使用了,这个

BLOCK 应该从 FREELIST 列表中移除 (un-link) 。为何要保留 10% 的空间呢?这是为了提供 update

数据时所可能增加的空间使用,如果空间保留的太小,就容易发生 row chaining 。

2.INITRANS和MAXTRANS

INITRANS表示块首部中事务表的初始大小,该值影响着对表的事务并发访问(表默认是1,索引默认是2);MAXTRANS表示事务表的

最大值,Oracle10g中默认值是255。

再看下面的解说:

INITRANS 指的是一个 BLOCK 上初始预分配给并行交易控制的空间 (ITLs)

( 当 BLOCK 上某笔 ROW 被交易更新锁定时,会在 BLOCK header ITL allocate

一个锁,当下一个交易要更新同一笔 row 时,就会发现他已经被先前的交易持有锁了,会先去检查该交易是否 active?

如果是,后来的该笔交易就会被 blocking ,等待 ) 如果一个表格需要同时有大量交易存取,你应该设定 INITRANS

大一点,可以减少 ITL 还要动态扩充的 Overhead 。

For tables INITRANS defaults to 1 for indexes 2

a4c26d1e5885305701be709a3d33442f.png

可用于:表空间、回滚段、表、索引、分区、快照、快照日志

a4c26d1e5885305701be709a3d33442f.png

建议PCTINCREASE参数设置为0,可使碎片最小化,使每一个Extent都相同(等于NEXT值)

一旦建立了某个对象,它的INITIAL和MINEXTENTS参数不能修改(Oracle 816中可修改MINEXTENTS参数)

对于NEXT和PCTINCREASE的任何修改都只影响后来分配的那些Extent

在分配一个新Extent时,系统直接按NEXT的值分配一个Extent,然后用公式:前一NEXT值*(1+PCTINCREASE/100)

计算出下一个应该分配的Extent的大小,并把计算结果保存到相关数据字典的NEXT_EXTENT列上,做为下一个应该分配的Extent的大小。

CREATE TABLE test(a number)

STORAGE(

INITIAL 100K

NEXT 100K

MINEXTENTS 2

MAXEXTENTS 100

PCTINCREASE 100);

解释:

初始给test表分配两个Extent,

第一个Extent是100K,因INITIAL=100K

第二个Extent是100K,因NEXT=100K

如果因表内数据增长,需要分配第三个Extent,因PCTINCREASE是100,则

第三个Extent是200K=100K+100K

第四个Extent是400K=200K+200K

可通过数据字典表DBA_TABLES、ALL_TABLES、USER_TABLES查看参数设置情况,如:

select

table_name,initial_extent,next_extent,min_extents,max_extents,pct_increase

from user_tables;

TABLE_NAME INITIAL_EXTENT NEXT_EXTENT MIN_EXTENTS MAX_EXTENTS

PCT_INCREASE

---------- -------------- ----------- ----------- -----------

------------

TEST        106496   212992      2     100     100

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值