管理表空间和数据文件概要

Posted kawashibara

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了管理表空间和数据文件概要相关的知识,希望对你有一定的参考价值。

管理数据库存储结构

 

表空间和数据文件

Oracle DB在逻辑上将数据存储在表空间中,在物理上将数据存储在数据文件中

表空间:

-只能属于一个数据库

-包括一个或多个数据文件

-可进一步划分为逻辑存储单元

数据文件:

-只能属于一个表空间和一个数据库

-是存储方案对象数据的资料档案库

 

System表空间 存了大量的系统表,包括一些数据字典和动态性能视图等

 

Sysaux 辅助表空间 作为SYSTEM表空间的辅助表空间.以前一些使用独立表空间或系统表空间的数据库组件现在在SYSAUX表空间中创建

 

Temp 临时表空间 临时表空间用来管理数据库排序操作以及用于存储临时表、中间排序结果等临时对象

 

UNDOTBS1 还原表空间

Users表空间存放永久用户信息的

Example表空间

 

查看数据库里所有表空间的信息

Desc dba_data_files;

select file_name,tablespace_name from dba_data_files;

/u01/app/oracle/oradata/VDEDU/users01.dbf   USERS

/u01/app/oracle/oradata/VDEDU/undotbs01.dbf   UNDOTBS1

/u01/app/oracle/oradata/VDEDU/sysaux01.dbf   SYSAUX

/u01/app/oracle/oradata/VDEDU/system01.dbf   SYSTEM

/u01/app/oracle/oradata/VDEDU/example01.dbf   EXAMPLE

 

select file_name,tablespace_name from dba_temp_files;

/u01/app/oracle/oradata/VDEDU/temp01.dbf   TEMP

 

创建表空间

SQL> create tablespace test datafile ‘/u01/app/oracle/oradata/VDEDU/test01.dbf‘ size 100m autoextend on;

 

Tablespace created.

 

扩大表空间

SQL> Alter tablespace test add datafile ‘/u01/app/oracle/oradata/VDEDU/test02.dbf’ size 100 m autoextend on;

创建临时表空间

Create temporary tablespace test tempfile ‘/u01/app/oracle/oradata/VDEDU/test01.dbf‘ size 100m autoextend on;

扩大临时表空间

Alter  tablespace test add tempfile ‘/u01/app/oracle/oradata/VDEDU/test01.dbf‘ size 100m autoextend on;

 

Alter user hr default tablespace test;使hr用户默认使用表空间test

Alter user hr temporary tablespace temptest;指定使用临时表空间

 

SQL> select tablespace_name,bytes/1024/1024||‘M‘ as "size" from dba_data_files;

 

TABLESPACE_NAME        size

------------------------------ -----------------------------------------

USERS        5M

UNDOTBS1        110M

SYSAUX        580M

SYSTEM        760M

EXAMPLE        346.25M

TEST        100M

TEST        100M

TEST2        100M

TEST2        100M

TEST3        100M

TEST3        100M

 

 

 

 

 

Oracle11gR2创建表空间基本模版

Create smallfile tablespace <tablespace_name>

Datafile<路径和文件名>size<文件大小>

Autoextend on next<每次扩展多大>maxsize {unlimited|nM/G/T} logging

Extent management {local|dictionary} {autoallocate|uniform size<区固定大小>}

Segment space management {auto|manual};  (段扩展)

 

段管理模式

ASSM:automatic segment space management(自动段空间管理)

MSSM:manual segment space management(手工段空间管理)

 

Select tablespace_name,segment_space_management from dba_tablespaces;

 

SQL> create tablespace tbs01 datafile ‘/u01/app/oracle/oradata/VDEDU/tbs0101.dbf‘ size 10m autoextend on extent management local autoallocate;--区扩展本地管理自动分配大小

 

SQL> create tablespace tbs02 datafile ‘/u01/app/oracle/oradata/VDEDU/tbs0201.dbf‘ size 100m autoextend on extent management local uniform size 10m;--区扩展本地管理固定大小

 

SQL> create tablespace ASSMTBS1 datafile ‘/u01/app/oracle/oradata/VDEDU/assmtbs1_01.dbf‘ size 10m segment space management auto; --自动段空间管理

 

SQL> create tablespace MSSMTBS1 datafile ‘/u01/app/oracle/oradata/VDEDU/mssmtbs1_01.dbf‘ size 10m

segment space management manual;--手工段空间管理

 

logging实际上是对象的一个属性,用来表示在创建对象时是否记录redo日志,包括在做dml时是否记录redo日志。一般表上不建议使用nologging,在创建索引或做大量数据导入时,可以使用nologging

以上是关于管理表空间和数据文件概要的主要内容,如果未能解决你的问题,请参考以下文章

oracle 数据库管理--管理表空间和数据文件

oracle 数据库管理--管理表空间和数据文件

操作系统-文件系统概要

Oracle数据文件和临时文件的管理

Oracle数据库基本操作——表空间管理

Oracle实验六—表空间与数据文件管理