简讨Oracle pctused参数

数据库 Oracle
pctfree和Oracle pctused参数的唯一目的就是为了控制块如何在freelists中进出。虽然freelistlink 和 unlink 是简单的 Oracle 功能,不过设置freelistlink (pctused) 和 unlink (pctfree) 对 Oracle 的性能确实有影响。

经过长时间学习Oracle pctused参数,于是和大家分享一下,看完本文你肯定有不少收获,希望本文能教会你更多东西。Oracle 的其中一个优点时它可以管理每个表空间中的自由空间。 Oracle 负责处理表和索引的空间管理,这样就可以让我们无需懂得 Oracle 的表和索引的内部运作。不过,对于有经验的 Oracle 调优专家来说,他需要懂得 Oracle 是如何管理表的 extent 和空闲的数据块。对于调整拥有高的 insert 或者 update 的系统来说,这是非常重要的。

要精通对象的调整,你需要懂得freelists和freelist组的行为,它们和pctfree及Oracle pctused参数的值有关。这些知识对于企业资源计划( ERP )的应用是特别重要的,因为在这些应用中,不正确的表设置通常是 DML 语句执行慢的原因。

对于初学者来说,最常见的错误是认为默认的 Oracle 参数对于所有的对象都是***的。除非磁盘的消耗不是一个问题,否则在设置表的pctfree和Oracle pctused参数时,就必须考虑平均的行长和数据库的块大小,这样空的块才会被有效地放到freelists中。当这些设置不正确时,那些得到的freelists也是 "dead" 块,因为它们没有足够的空间来存储一行,这样将会导致明显的处理延迟。

Freelists 对于有效地重新使用 Oracle 表空间中的空间是很重要的,它和pctfree及pctused这两个存储参数的设置直接相关。通过将pctused设置为一个高的值,这时数据库就会尽快地重新使用块。不过,高性能和有效地重新使用表的块是对立的。在调整 Oracle 的表格和索引时,需要认真考虑究竟需要高性能还是有效的空间重用,并且据此来设置表的参数。以下我们来看一下这些freelists是如何影响 Oracle 的性能的。

当有一个请求需要插入一行到表格中时, Oracle 就会到freelist中寻找一个有足够的空间来容纳一行的块。你也许知道,freelist串是放在表格或者索引的***个块中,这个块也被称为段头( segment header )。pctfree和Oracle pctused参数的唯一目的就是为了控制块如何在freelists中进出。虽然freelistlink 和 unlink 是简单的 Oracle 功能,不过设置freelistlink (pctused) 和 unlink (pctfree) 对 Oracle 的性能确实有影响。

由 DBA 的基本知识知道,pctfree参数是控制freelistun-links 的(即将块由freelists中移除)。设置 pctfree=10 意味着每个块都保留 10% 的空间用作行扩展。Oracle pctused参数是控制freelistre-links 的。设置 pctused=40 意味着只有在块的使用低于 40% 时才会回到表格的freelists中。

许多新手对于一个块重新回到freelists后的处理都有些误解。其实,一旦由于一个删除的操作而令块被重新加入到freelist中,它将会一直保留在freelist中即使空间的使用超过了 60% ,只有在到达pctfree时才会将数据块由freelist中移走。

【编辑推荐】

  1. 快速掌握Oracle参数设置
  2. 事例解析Oracle函数
  3. Oracle Sequence之深入浅出
  4. 你是否了解Oracle触发器
  5. 详细描述Oracle系统特权
责任编辑:佚名 来源: it168
相关推荐

2009-11-18 14:53:40

Oracle参数设置

2010-01-25 10:10:42

C++函数参数

2010-07-05 10:04:44

linux ftp命令

2010-10-27 16:14:24

Oracle参数查询命

2010-11-15 10:40:58

Oracle启动参数

2010-04-19 10:20:19

Oracle参数

2010-04-19 17:08:01

Oracle参数

2022-05-23 13:24:20

碳中和

2009-04-28 09:25:15

Oracle系统参数优化

2010-04-13 16:45:47

Oracle job

2010-11-19 09:30:01

Oracle创建实例

2022-04-25 14:41:15

甲骨文数据库机数据库

2010-04-29 16:15:06

Oracle flas

2010-04-16 11:39:56

Oracle存储过程

2009-03-11 12:57:33

虚拟化微软IT

2010-04-12 10:46:02

Oracle性能测试

2010-05-10 11:26:40

Oracle 参数文件

2010-05-10 13:11:29

Oracle启动

2010-04-29 14:23:08

Oracle初始参数
点赞
收藏

51CTO技术栈公众号