现在的位置: 首页 > 综合 > 正文

Oracle 表空间与数据文件

2012年08月01日 ⁄ 综合 ⁄ 共 3656字 ⁄ 字号 评论关闭

--==============================

--Oracle 表空间与数据文件

--==============================

/*

一、概念

    表空间:是一个或多个数据文件的逻辑集合

    表空间逻辑存储对象:永久段-->如表与索引

                        临时段-->如临时表数据与排序段

                     回滚段-->用于事物回滚或闪回内存的撤销数据

    表空间分类:系统表空间(systemsysaux),非系统表空间

   

    一个表空间至少包含一个数据文件,一个数据文件只能属于一个表空间。

   

    不可或缺的几个表空间:

    SYSTEM --->字典表空间,不能被损坏

    UNDO    --->dml,dql把数据快照到此,数据提交即消失(用于恢复)

    SYSAUX  --->10g 高并发系统繁忙时,会造成system争用,将工具放到SYSAUX,减轻system的压力,SYSAUX不影响系统(影响性能)

    TEMP    --->临时数据相关的内容

    USERS   --->10g  用户数据从system拨离出来

   

   

二、Oracle的存储结构

    1.Schema: 用户--->创建相关对象、表、视图、序列、函数、存储过程、包等

    2.逻辑结构:database数据库--->tablespace表空间---> segment--->extent区间----> block

            逻辑结构是Oracle内部管理数据库中对象的方式

    3.物理结构:OS  block --->datafile 物理结构通常是一系列数据文件

    4.举例描述scott用户创建对象的组织方式 */

   

--查看scott用户的默认表空间及数据文件

    SQL> select USERNAME,DEFAULT_TABLESPACE,TEMPORARY_TABLESPACE                                       

      2  from dba_users

      3  where username = 'SCOTT';

 

    USERNAME                       DEFAULT_TABLESPACE             TEMPORARY_TABLESPACE

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

    SCOTT                          USERS                          TEMP

 

    SQL> col name format a50

    SQL> select t1.name,t2.name   --查看表空间及数据文件

      2  from v$tablespace t1,v$datafile t2

      3  where t1.ts# = t2.ts#;

 

    NAME                                               NAME

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

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

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

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

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

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

 

/*

    scott-->emp(table)-->数据定义(位于)-->system表空间

                      数据(位于)  -->user表空间(逻辑存储)-->表段-->区间-->内存块

                                                    -->索引段等-->区间-->内存块

                                user表空间(物理存储)-->user01.dbf

                                   -->采用本地管理,包含头部信息,可用、已用等位图信息

                                  

    databuffer缓冲区满则调用dbwr进程将数据写入到物理文件当中 */

    /*

 

三、创建表空间

 

    --简要语法:

    CREATE [BIGFILE | SMALLFILE] [TEMPORARY] TABLESPACE tablespace name

    DATAFILE datafile spec | TEMPFILE tempfile spec

    [MINIMUM EXTENT minimum extent size]

    [BLOCKSIZE blocksize]

    [[COMPRESS|NOCOMPRESS] DEFAULT STORAGE (default storage clause)]

    [LOGGING|NOLOGGING]

    [FORCE LOGGING]

    [ONLINE|OFFLINE]

    [EXTENT MANAGEMENT DICTIONARY |

    LOCAL [AUTOALLOCATE|UNIFORM SIZE size]]

    [SEGMENT SPACE MANAGEMENT MANUAL|AUTO]

    [FLASHBACK ON|OFF]

   

    --创建表空间的条件

    1.具有create tablespace的权限,DBA角色具有该权限,sysdba,sysoper

    2.创建的是bigfiel ,还是smallifle  超过T 级别应考虑bigfile

    3.新建的表空间的I/O,是否会导致磁盘I/O不够用

    4.datafile后跟的路径应该具备写的权限  */

   

    --查看缺省是BIGFILE 还是SMALLFILE,当缺省为SMALLFILE,创建表空间不指定表空间类型则为SMALLFILE

    SQL> select PROPERTY_NAME,PROPERTY_VALUE from database_properties where PROPERTY_NAME like '%TBS%';

 

    PROPERTY_NAME                  PROPERTY_VALUE

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

    DEFAULT_TBS_TYPE               SMALLFILE

   

    --修改创建表空间为大或小表空间的默认值

    SQL> alter database set default bigfile tablespace;

 

    Database altered.

 

    SQL> select PROPERTY_NAME,PROPERTY_VALUE from database_properties where PROPERTY_NAME like '%TBS%';

 

    PROPERTY_NAME                  PROPERTY_VALUE

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

    DEFAULT_TBS_TYPE               BIGFILE

   

    --改回为缺省值

    SQL> alter database set default smallfile tablespace;

-->

作者:

抱歉!评论已关闭.