版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第9周 高水位线杨进一、一、ORACLE的逻辑存储管理的逻辑存储管理. ORACLE在逻辑存储上分4个粒度: 表空间表空间, 段段, 区区 和和 块块. 1.1 块块: 是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是说当ORACLE从数据文件读数据时,是读取多少个块,而不是多少行. 每一个Block里可以包含多个row. 1.2 区区: 由一系列相邻的块而组成,这也是ORACLE空间分配的基本单位,举个例子来说,当我们创建一个表Tab_1时,首先ORACLE会分配一区的空间给这个表,随着不断的INSERT数据到Tab_1,原来的这个区容不下插
2、入的数据时,ORACLE是以区为单位进行扩展的,也就是说再分配多少个区给Tab_1,而不是多少个块. 一、一、ORACLE的逻辑存储管理的逻辑存储管理. ORACLE在逻辑存储上分4个粒度: 表空间表空间, 段段, 区区 和和 块块. 1.3 段段: 是由一系列的区所组成, 一般来说, 当创建一个对象时(表,索引),就会分配一个段给这个对象. 所以从某种意义上来说,段就是某种特定的数据.如CREATE TABLE Tab_1,这个段就是数据段,而CREATE INDEX ON Tab_1(NAME), ORACLE同样会分配一个段给这个索引,但这是一个索引段了.查询段的信息可以通过数据字典:
3、SELECT * FROM USER_SEGMENTS来获得. 1.4 表空间表空间: 包含段,区及块.表空间的数据物理上储存在其所在的数据文件中.一个数据库至少要有一个表空间. 当我们创建了一个表,即使我没有插入任何一行记录, ORACLE还是给它分配了8个块. 也就是说,在这个对象创建以后,ORACLE至少给它分配一个区,初始大小是64K,一个标准块的大小是8K,刚好是8个BLOCK. 二二. 高水线高水线(High Water Mark) 2. 1 Oracle表段中的高水位线表段中的高水位线HWM 在Oracle数据的存储中,可以把存储空间想象为一个水库,数据想象为水库中的水。水库中的
4、水的位置有一条线叫做水位线,在Oracle中,这条线被称为高水位线(High-warter mark, HWM)。在数据库表刚建立的时候,由于没有任何数据,所以这个时候水位线是空的,也就是说HWM为最低值。当插入了数据以后,高水位线就会上涨,但是这里也有一个特性,就是如果你采用就是如果你采用delete语语句删除数据的话,数据虽然被删除了,但是高水位线却句删除数据的话,数据虽然被删除了,但是高水位线却没有降低没有降低,还是你刚才删除数据以前那么高的水位。也就是说,这条高水位线在日常的增删操作中只会上涨,不会下跌。HWM通常增长的幅度为一次5个数据块. Select语句会对表中的数据进行一次扫描
5、,但是究竟扫描多少数据存储块呢,并不是说数据库中有多少数据,Oracle就扫描这么大的数据块,而是Oracle会扫描高水位会扫描高水位线以下的数据块线以下的数据块。现在来想象一下,如果刚才是一张刚刚建立的空表,你进行了一次Select操作,那么由于高水位线HWM在最低的0位置上,所以没有数据块需要被扫描,扫描时间会极短。而如果这个时候你首先插入了一千万条数据,然后再用delete语句删除这一千万条数据。由于插入了一千万条数据,所以这个时候的高水位线就在一千万条数据这里。后来删除这一千万条数据的时候,由于delete语句不影响高水位线,所以高水位线依然在一千万条数据这里。这个时候再一次用sele
6、ct语句进行扫描,虽然这个时候表中没有数据,但是由于扫描是按照高水位线来的,所以需要把一千万条数据的存储空间都要扫描一次,也就是说这次扫描所需要的时间和扫描一千万条数据所需要的时间是一样多的。所以有时候有人总是经常说,怎么我的表中没有几条数据,但是还是这么慢呢,这个时候其实奥秘就是这里的高水位线了。 那有没有办法让高水位线下降呢,其实有一种比较简单的方法,那就是采用就是采用TRUNCATE语句进行删除数据语句进行删除数据。采用TRUNCATE语句删除一个表的数据的时候,类似于重新建立了表,不仅把数据都删除了,还把HWM给清空恢复为0。所以如果需要把表清空,在有可能利用TRUNCATE语句来删除
7、数据的时候就利用TRUNCATE语句来删除表,特别是那种数据量有可能很大的临时存储表。 在手动段空间管理(Manual Segment Space Management)中,段中只有一个HWM,但是在Oracle 9i Release1才添加的自动段空间管理(Automatic Segment Space Management)中,又有了一个低又有了一个低HWM的概念出来的概念出来。为什么有了HWM还又有一个低HWM呢,这个是因为自动段空间管理的特性造成的。在手段段空间管理中,当数据插入以后,如果是插入到新的数据块中,数据块就会被自动格式化等待数据访问。 而在自动段空间管理中,数据插入到新的数
8、据块以后,数据块并没有被格式化,而是在第一次访问这个数据块的时候才格式化这个块。所以我们又需要一条水位线,用来标示已经被格式化的块。这条水位线就叫做低HWM。一般来说,低HWM肯定是低于等于HWM的。 2.2. 修正ORACLE表的高水位线 在ORACLE中,执行对表的删除操作不会降低该表的高水位线。而全表扫描将始终读取一个段(extent)中所有低于高水位线标记的块。如果在执行删除操作后不降低高水位线标记,则将导致查询语句的性能低下。 2.2.1 执行表重建指令执行表重建指令 alter table table_name move; 2.2.2 执行执行alter table table_n
9、ame shrink space; 此命令为Oracle 10g新增功能,再执行该指令之前必须允许行移动 alter table table_name enable row movement; 2.2.3 重建表重建表 复制要保留的数据到临时表t,drop原表,然后rename临时表t为原表 2.2.4 用逻辑导入导出用逻辑导入导出: Emp/Imp 2.2.5. Alter table table_name deallocate unused DEALLOCATE UNUSED为释放HWM上面的未使用空间,但是并不会释放HWM下面的自由空间,也不会移动HWM的位置. 2.2.6 推荐使用推荐
10、使用truncate. 2.3 HWM 特点特点 2.3.1 ORACLE用用HWM来界定一个段中使用的块和来界定一个段中使用的块和未使用的块未使用的块. 举个例子来说,当我们创建一个表时,ORACLE就会为这个对象分配一个段. 在这个段中,即使我们未插入任何记录,也至少有一个区被分配,第一个区的第一个块就称为段头(SEGMENT HEADE),段头中就储存了一些信息,基中HWM的信息就存储在此. 此时,因为第一个区的第一块用于存储段头的一些信息,虽然没有存储任何实际的记录,但也算是被使用,此时HWM是位于第2个块. 当我们不断插入数据到表后,第1个块已经放不下后面新插入的数据,此时,ORAC
11、LE将高水位之上的块用于存储新增数据,同时,HWM本身也向上移.也就是说,当我们不断插入数据时,HWM会往不断上移,这样,在HWM之下的,就表示使用过的块,HWM之上的就表示已分配但从未使用过的块2.3.2. HWM在插入数据时在插入数据时,当现有空间不足而进行空间的当现有空间不足而进行空间的扩展时会向上移扩展时会向上移,但删除数据时不会往下移但删除数据时不会往下移. ORACLE 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM), 2.3.3. HWM的信息存储在段头当中的信息存储在段头当中. HWM本身的信息是储存在段头.在段空间是手工管理方式时,ORACLE是通过FREELIST(一个单向链表)来管理段内的空间分配.在段空间是自动管理方式时(ASSM),ORACLE是通过BITMAP来管理段内的空间分配. 2.3.4. ORACLE的全表扫描是读取高水位标记的全表扫描是读取高水位标记(HWM)以下的以下的所有块所有块. 当用户发出一个全表扫描时,ORACLE 始终必须从段一直扫描到 HWM,即使它什么也没有发现。该任务延长了全表扫描的时间。 2.3.5. 当用直接路径插入行时,即使当用直接路径插入行时
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 深度解析(2026)《GBT 33339-2016全钒液流电池系统 测试方法》(2026年)深度解析
- (正式版)DB12∕T 882-2019 《羊包虫病防治技术规程 》
- 任务3.3采用CVS文件批量标记发货
- 5G-A实训任务-专网实操课件1
- 《鱼我所欲也》第一课时【从基到通】九年级语文下册重点课文教学(统编版)
- 医疗数据安全成熟度评估:区块链技术与医疗物联网结合
- 医疗数据安全态势感知的共识机制应用
- 医疗数据安全威胁情报的共识机制共享
- 胸整形课件教学课件
- 【9历第三次月考】安徽省宿州九中教育集团2025-2026学年九年级上学期12月月考历史试题(含解析)
- 2025年韩家园林业局工勤岗位工作人员招聘40人备考题库及参考答案详解一套
- 四川省达州市达川中学2025-2026学年八年级上学期第二次月考数学试题(无答案)
- 2025陕西西安市工会系统开招聘工会社会工作者61人历年题库带答案解析
- 江苏省南京市秦淮区2024-2025学年九年级上学期期末物理试题
- 债转股转让协议书
- 外卖平台2025年商家协议
- (新教材)2026年人教版八年级下册数学 24.4 数据的分组 课件
- 老年慢性病管理及康复护理
- 2025广西自然资源职业技术学院下半年招聘工作人员150人(公共基础知识)测试题带答案解析
- 2026年海南经贸职业技术学院单招(计算机)考试参考题库及答案1套
- 2025天津大学管理岗位集中招聘15人备考考点试题及答案解析
评论
0/150
提交评论