oracle表空间管理

简介:

                                           管理表空间
一: 设置表空间的只读状态
1 read-only的前提条件:
表空间必须online
表空间不能是undo 表空间或者system表空间
表空间不能处于在线备份状态
2 使表空间read-only 的语句
alter tablespace zx read only;
3 使表空间可读可写
alter tablespace zx read write;
4 eg:
 SQL> alter tablespace zx read only;

Tablespace altered.

SQL> alter tablespace zx read write;

Tablespace altered.

二 表空间的维护
1 增加表空间的大小
 增加数据文件
 alter tablespace zx add datafile '/oracle/CRM2/CRM/zx3.dbf' size 1m;
 调整数据文件大小为自动增长
 alter  database datafile '/oracle/CRM2/CRM/zx2.dbf' autoextend on;
 eg: 
SQL> alter database datafile '/oracle/CRM2/CRM/zx2.dbf' autoextend on;
Database altered.
SQL> alter database datafile '/oracle/CRM2/CRM/zx2.dbf' autoextend off;
Database altered.


三大数据文件表空间的创建和修改
1 大数据文件表空间创建注意事项
指定bigfile关键字oracle将创建一个本地管理以及段自动管理的表空间。
创建时可以指定 extent management local和segment space management auto。
如果指定 extent management dictionary 或者 segment space managemnet manual 将报错。
2 语句
create bigfile tablespace zxbigtbs 
            datafile '/oracle/CRM2/CRM/zxbig1.dbf' size 1G;
size 单位可以指定k/m/g/t/
3 查询数据库内部的大表空间
 可查询视图dba_tablespaces、user_tablespaces、v$tablespace 的bigfile字段
 eg:
 
SQL> select tablespace_name,bigfile from dba_tablespaces;

TABLESPACE_NAME                BIG
------------------------------ ---
SYSTEM                         NO
SYSAUX                         NO
TEMP                           NO
USERS                          NO
UNDOTBS2                       NO
ZX                             NO
ZXBIGTBS                       YES
4 修改大数据文件的表空间
调整大小
alter tablespace zxbigtbs resize 2G;
调整数据文件自动扩展
alter tablespace zxbigtbs autoextend on next 20G;
四 临时表空间
 1 新安装的oracle 默认会创建一个temp临时表空间
   用户可以创建额外的临时表空间
   可以给数据库每一个用户指定一个临时表空间
   用户不能明确的在临时表空间中创建对象
   
 2  默认的临时表空间
 如果用户没有明确指定临时表空间,则用户默认临时表空间为temp
 更改数据库默认临时表空间
 alter database default temporary tablespace 表空间名字;
 确认当前数据库默认的临时表空间
 select property_name,property_value from database_properties where property_name='DEFAULT_TEMP_TABLESPACE'

PROPERTY_NAME                  PROPERTY_VALUE
------------------------------ ------------------------------
DEFAULT_TEMP_TABLESPACE        TEMP

3 创建本地管理的临时表空间
create temporary tablespace mytemp tempfile '/oracle/CRM2/CRM/mytemp.dbf' size 200M autoextend on next 10M maxsize 1G;

4 创建一个大数据文件的临时表空间以及对该大表空间的修改
create bigfile temporary tablespace mynewtemp tempfile '/oracle/CRM2/CRM/newtemp.dbf' size 2G;
SQL> alter tablespace mynewtemp resize 3G;
Tablespace altered.
SQL> alter tablespace mynewtemp autoextend on next 20G maxsize 40G;
Tablespace altered.

5 11g下查询临时表空间的使用率

SQL> select * from dba_temp_free_space;

TABLESPACE_NAME                TABLESPACE_SIZE ALLOCATED_SPACE FREE_SPACE
------------------------------ --------------- --------------- ----------
TEMP                                 228589568       228589568  227540992
MYNEWTEMP                           3221225472         1048576 3220176896

5 临时表空间组
临时表空间组的特性:
a 至少包括一个表空间,对表空间个数无明确限制
b 可以把临时表空间组名,作为数据库默认的表空间,或者分配给用户。
c 如果临时表空间组被作为默认的临时表空间,则不能直接丢弃组内任何成员,需要先从组内移除该表空间。
创建临时表空间组
  临时表空间组不能直接被创建,只能间接创建
  语句:
  方式一: create temporary tablespace ltemp1 tempfile '/oracle/CRM2/CRM/ltemp01.dbf' size 50M tablespace group tempgroup1;
  方式二:  create temporary tablespace ltemp2 tempfile '/oracle/CRM2/CRM/ltemp02.dbf' size 50M;
         alter tablespace ltemp2 tablespace group tempgroup2;
eg:
方式一:SQL>  create temporary tablespace ltemp1 tempfile '/oracle/CRM2/CRM/ltemp01.dbf' size 50M tablespace group tempgroup1;

Tablespace created.
 
SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1

方式二:SQL> create temporary tablespace ltemp2 tempfile '/oracle/CRM2/CRM/ltemp02.dbf' size 50M;

Tablespace created.

SQL> alter tablespace ltemp2 tablespace group tempgroup2;

Tablespace altered.

SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1
TEMPGROUP2                     LTEMP2
对临时表空间组的修改
移动组内的成员语句:alter tablespace ltemp2 tablespace group tempgroup1;
从组内删除某个临时表空间语句: alter tablespace ltemp2 tablespace group ‘’;
eg: 移动组内成员(注意ltemp2属于组tempgroup2也可以直接从组2移动到组1)
   SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1
TEMPGROUP2                     LTEMP2

SQL> alter tablespace ltemp2 tablespace group tempgroup1;

Tablespace altered.

SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1
TEMPGROUP1                     LTEMP2

eg:删除组内某个临时表空间
   SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1
TEMPGROUP1                     LTEMP2

SQL> alter tablespace ltemp2 tablespace group '';

Tablespace altered.

SQL> select * from dba_tablespace_groups;

GROUP_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
TEMPGROUP1                     LTEMP1
分配一个临时表空间组作为数据库默认临时表空间
语句:alter database default temporary tablespace 组名; 
eg 
SQL> alter database default temporary tablespace tempgroup1;

Database altered

select property_name,property_value from database_properties where property_name='DEFAULT_TEMP_TABLESPACE'

PROPERTY_NAME                  PROPERTY_VALUE
------------------------------ ------------------------------
DEFAULT_TEMP_TABLESPACE        TEMPGROUP1

五:重命名表空间
注意事项
1 compatible 参数必须设置成10.0.0 或更高
2 不能重命名system、sysaux表空间
3 重命名时应先检查表空间对应的数据位置是否离线,如果离线,重命名则报错。
4 最好表空间read write 否则数据文件头部记录的表空间名不更新。
5 当重命名时,将更新所有和该表空间有关的数据字典,控制文件,和在线数据文件头部。
6 如果表空间是临时表空间,更名后,视图database_properties将自动更新并使用新的临时表空间名。
语句 alter tablespace 表空间名 rename to  新表空间名
eg:
SQL> alter tablespace mytemp rename to testtemp;

Tablespace altered.

SQL> select tablespace_name from dba_tablespaces;

TABLESPACE_NAME
------------------------------
SYSTEM
SYSAUX
TEMP
USERS
UNDOTBS2
ZX
ZXBIGTBS
TESTTEMP
LTEMP1
LTEMP2
六 drop 表空间
参数说明:
including contents 将丢弃表空间所有段 如果表空间是空的,不包括任何表,视图,结构,则不需要指定该参数
cascade constraints 将丢弃所有引用和约束
including contents and datafiles 丢弃表空间的同时删除数据文件
语句drop tablespace 表空间 including contents and datafiles;
eg
SQL> select tablespace_name from dba_tablespaces;

TABLESPACE_NAME
------------------------------
SYSTEM
SYSAUX
TEMP
USERS
UNDOTBS2
ZX
ZXBIGTBS
TESTTEMP
LTEMP1
LTEMP2

10 rows selected.

SQL> drop tablespace testtemp including contents and datafiles;

Tablespace dropped.

  
 










本文转自 zhangxuwl 51CTO博客,原文链接:http://blog.51cto.com/jiujian/1035174,如需转载请自行联系原作者
相关实践学习
简单用户画像分析
本场景主要介绍基于海量日志数据进行简单用户画像分析为背景,如何通过使用DataWorks完成数据采集 、加工数据、配置数据质量监控和数据可视化展现等任务。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
目录
相关文章
|
2月前
|
存储 Oracle NoSQL
Oracle 表空间、数据文件、schema的关系
Oracle 表空间、数据文件、schema的关系
32 2
|
6月前
|
Oracle 关系型数据库 数据库
9-4 Oracle管理表空间和数据文件
9-4 Oracle管理表空间和数据文件
|
7月前
|
SQL 监控 Oracle
Oracle创建和管理表空间
Oracle创建和管理表空间
59 1
|
1月前
|
存储 Oracle 关系型数据库
Oracle系列之七:表的创建与管理
Oracle系列之七:表的创建与管理
|
1月前
|
Oracle 关系型数据库 数据库
Oracle系列之五:Oracle表空间
Oracle系列之五:Oracle表空间
|
4月前
|
SQL Oracle 关系型数据库
Oracle查看表空间 及表空间是否需要扩展
Oracle查看表空间 及表空间是否需要扩展
26 0
|
4月前
|
运维 Oracle 关系型数据库
医院检验科LIS系统源码,oracle数据库、报告管理、质控管理
医院检验科LIS系统源码,oracle数据库、报告管理、质控管理
52 0
|
6月前
|
存储 Oracle 关系型数据库
9-6 Oracle 管理索引
9-6 Oracle 管理索引
|
8月前
|
缓存 Oracle 关系型数据库
使用序列(Sequence)在 Oracle 数据库中管理唯一标识符
使用序列(Sequence)在 Oracle 数据库中管理唯一标识符
103 0
|
10月前
|
Oracle 关系型数据库
Oracle提示表空间不足ORA-01653:
Oracle提示表空间不足ORA-01653:
89 0