深谈Oracle Freelist经验

数据库 Oracle
这里介绍Oracle Freelist中寻找一个有足够的空间来容纳一行的块。你也许知道,Freelist串是放在表格或者索引的第一个块中,这个块也被称为段头(segment header)。

Oracle有很多值得学习的地方,这里我们主要介绍Oracle Freelist,包括介绍Freelists等方面。Oracle的其中一个优点时它可以管理每个表空间中的自由空间。Oracle负责处理表和索引的空间管理,这样就可以让我们无需懂得Oracle 的表和索引的内部运作。不过,对于有经验的Oracle调优专家来说,他需要懂得Oracle是如何管理表的extent和空闲的数据块。对于调整拥有高的insert或者update的系统来说,这是非常重要的。

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

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

Oracle Freelist对于有效地重新使用Oracle表空间中的空间是很重要的,它和pctfree及pctused这两个存储参数的设置直接相关。

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

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

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

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

【编辑推荐】

  1. Oracle Spatial学习经验
  2. 高手谈论Oracle Spatial
  3. 全面概括Oracle数据类型
  4. 快速了解Oracle SQL语言
  5. 你是否了解Oracle Dual表
责任编辑:佚名 来源: IT168
相关推荐

2009-12-18 18:29:43

Linux Fedor

2009-11-10 10:24:28

Visual Stud

2009-11-17 10:40:45

2010-04-02 12:51:14

Oracle安装

2010-03-12 09:19:55

LTE广域无线视频监控

2009-12-25 13:58:15

LINUX光标移动

2010-04-12 12:55:24

Oracle 安装经验

2011-09-09 09:50:40

Oracle

2009-11-13 16:53:12

Oracle文档

2010-04-08 18:12:39

无线局域网传输

2009-12-30 09:22:01

Ubuntu编译

2010-03-24 13:19:38

云计算服务平台

2010-04-15 11:15:04

2010-03-11 16:13:42

云计算平台

2010-04-15 18:46:53

Unix操作系统

2009-12-29 15:18:01

Ubuntu menu

2009-12-22 17:32:40

Fedora linu

2010-04-15 17:29:32

2010-04-30 15:45:56

Oracle临时表

2010-05-06 17:30:56

Oracle查询语句
点赞
收藏

51CTO技术栈公众号