表的存储结构

逻辑存储概念(只在oracle层面上能够看到,在操作系统层面上是看不到的):段segment,区extent,块block,表空间tablespace

段:就是数据库中用于某种目的的存储空间,如表段用于存储表的数据,索引表用于存储索引数据。提到segment时强调其存储结构,而如果说表和索引,强调内部逻辑数据

区:Oracle分配存储空间的单位,段由若干个区组成,每个区是属于一个数据文件的一块连续空间(构成数据文件的空间也许不连续,但是区一定是连续的)段中多个区可以属于不同的数据文件。区的大小可以在创建表空间时指定为固定,也可以由oracle自动分配。

块:读写数据的单位,区即由连续的数据块构成。全表扫描时,每次从磁盘读取的数据块数量由初始化参数db_file_multiblock_read_count决定,默认为16。一个数据块默认为8kb,创建表空间时,用户可以指定
块的结构:块头、表目录、行目录、自由空间、数据、尾部

表空间:用户创建数据表或索引时,其对应的段被存进指定的表空间。每个段只能属于一个表空间,而一个表空间可以包含多个段。表空间由多个数据文件组成

表空间种类:
 系统表空间:  只有一个,叫system
 undo表空间: 须指定,未指定数据存入system表空间
 临时表空间: 排序或散列时如果内存不够,数据把中间结果存储于临时表空间
 用户表空间: 存放用户数据
 sysaux表空间

extent两种分配方式:autoallocate以及uniform size

用 delete删除表中的大部分记录后,多数的数据块应该都为空,但表所占用的数据块依然与原来相同。所占用的空间并不释放,做全表扫描的时候读取磁盘次数和删除记录前相同。

如果移动表中数据到另外一个表空间时,数据会重组,空数据块也会被释放。

truncate操作是DDL语句,执行此命令后,除了记录被清空,表占用的空间也被释放。但是,正是因为DDL语句,所以执行之后不能回滚

用 drop table命令把表删除之后,表占用的空间会同时被释放


移动数据文件有以下两个方法:
一:不必重启数据库,但要把表空间脱机,然后在操作系统上移动数据文件,并修改数据库对此文件路径的记载,再把表空间联机
二: 重启数据库到mount状态,然后再操作系统上移动数据文件,并修改数据库对此文件的路径记载,再把数据库打开到正常状态


alter tablespace users rename datafile(仅能移动一个表空间内的数据文件)
  f11.dbf,f12.dbf
to
  f21.dbf, f22.dbf;


alter tablespace users rename file
  f11.dbf,f12.dbf
to
  f21.dbf, f22.dbf; 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值