oracle表空间如何自动扩展?

oracle表空间如何自动扩展?,第1张

需要在创建的时候就设置为自动扩展,语句如下:

create  tablespace shopping --创建shopping的表空间

datafile 'shopping.dbf'  --物理文件名

size 50m  --初始大小为50M

autoextend on  --自动扩展

next 50m maxsize 20480m  --每次自动扩展50M,最大可到20480M

extent management local

表空间:

表空间是数据库的逻辑划分,一个表空间只能属于一个数据库。所有的数据库对象都存放在指定的表空间中。但主要存放的是表, 所以称作表空间。

Oracle数据库中至少存在一个表空间,即SYSTEM的表空间。

SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计。Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献。可以这么说,Oracle中很多优化都是基于表空间的设计理念而实现的。

在 Oracle 数据库中,一个表空间(tablespace)是由一个或多个数据文件(datafile)组成的逻辑存储单元,用于存储数据库对象,如表、索引、存储过程等。

当一个表空间中的数据文件没有足够的空间来存储新的数据时,Oracle 会自动扩展这个表空间,以便继续存储数据。这个扩展过程称为“表空间的自动扩展”。

在 Oracle 中,表空间的自动扩展有两种方式:一种是增加数据文件,另一种是使用 EXTENTS。EXTENTS 是一种逻辑数据结构,是用来描述表空间中的空闲空间的。当表空间需要扩展时,Oracle 会从 EXTENTS 中获取空闲空间,用来存储新的数据。

一个 EXTENT 是由若干个连续的数据块组成,可以存储一个或多个数据库对象。EXTENTS 在表空间中形成一个链,每个 EXTENT 都指向下一个 EXTENT,形成一个链式结构,用于存储数据。当一个数据库对象需要扩展时,Oracle 会根据这个对象的大小,分配一个或多个新的 EXTENT,并将这些 EXTENT 插入到表空间的链中,用于存储新的数据。

因此,EXTENTS 是 Oracle 中表空间自动扩展的一种方式,用于描述表空间中的空闲空间,以便存储新的数据。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11603617.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-17
下一篇2023-05-17

发表评论

登录后才能评论

评论列表(0条)

    保存