一 : oracle增加表空间的四种方法
增加表空间大小的四种方法
Meathod1:给表空间增加数据文件
ALTER TABLESPACE app_data ADD DATAFILE
'D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP03.DBF' SIZE 50M;
Meathod2:新增数据文件,并且允许数据文件自动增长
ALTER TABLESPACE app_data ADD DATAFILE
'D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP04.DBF' SIZE 50M
AUTOEXTEND ON NEXT 5M MAXSIZE 100M;
Meathod3:允许已存在的数据文件自动增长
ALTER DATABASE DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP03.DBF'
AUTOEXTEND ON NEXT 5M MAXSIZE 100M;
Meathod4:手工改变已存在数据文件的大小
ALTER DATABASE DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\EDWTEST\APP02.DBF'
RESIZE 100M;
作者“To_Be_Monster_Of_IT”
二 : Oracle调整表空间大小——ORA-03297: 文件包含在请求的 RESIZE 值以外使
将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。[www.61k.com)
如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
转载网址:
SQL> ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m;
ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m
*
ERROR 位于第 1 行:
ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
但是
SQL>select d.filename,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte
2 from dba_data_files d,dba_free_space f
3 where d.file_id=f.file_id and d.file_id=18
4 group by d.file_name,d.file_id,d.bytes/1024/1024;
FILE_NAME FILE_ID D_BYTE FREE_BYTE
--------------------------------- ---------- ---------- ----------
D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA 18 1536 1482.0625
可以看到实际上ID=18的文件只使用了大概50M左右,只是数据分布在(按一定的顺序)50M甚至在300M以外的地方,所以这里虽然看到只使用了约50M空间,但是却不能resize datafile.
为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:
1、移动表前先对表空间做整理
SQL>alter tablespace ic_data coalesce;
2、在dba_extents找到与ID=18的数据文件相关的表及索引
SQL>select segment_name,partition_name,segment_type
2 from dba_extents
3 where file_id=18;
3、对id=18的文件上的表和索引移动位置
SQL> set heading off
SQL> set echo off
SQL> set feedback off
SQL> set termout on
SQL> spool d:\aaa.sql
//移动表
SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace test_space;' from dba_extents where segment_type='TABLE' and file_id=18;
//移动索引
SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild tablespace test_space;' from dba_extents where segment_type='INDEX' and file_id=18;
//移动分区表
SQL>select DISTINCT 'alter table '|| segment_name || ' move partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='TABLE PARTITION' and file_id=18;
//移动分区索引
SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='INDEX PARTITION' and file_id=18;
SQL>spool off
然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,
其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便
4、这样移动了所有的数据以后就可以对datafile resize了
SQL> c/9/3
1* ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M
SQL> /
数据库已更改。
5、把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。
以上操作起源于我删除了database里的一个大表造成很多空间浪费,想回收空间:)
-----------------------分割线-----------------------------分割线-----------------------------分割线----------------------------
经过实践,以上方法可以处理ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。
但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错。
扩展:ora 03297 / oracle ora 03297 / oracle resize 表空间
三 : 如何在控制台创建oracle表空间
[oracle 创建表空间]如何在控制台创建oracle表空间——简介ORACLE数据库被划分成称作为表空间的逻辑区域——形成ORACLE数据库的逻辑结构。一个ORACLE数据库能够有一个或多个表空间,而一个表空间则对应着一个或多个物理的数据库文件。表空间是ORACLE数据库恢复的最小单位,容纳着许多数据库实体,如表、视图、索引、聚簇、回退段和临时段等。
[oracle 创建表空间]如何在控制台创建oracle表空间——知识点
Oracle 11g
[oracle 创建表空间]如何在控制台创建oracle表空间——详细知识
[oracle 创建表空间]如何在控制台创建oracle表空间 一
打开IE输入控制台网址(https://IP:1158/em/),用具有DBA权限的用户登陆oracle控制台

[oracle 创建表空间]如何在控制台创建oracle表空间 二
登陆控制台首页是数据库一般信息的信息监控画面,这里可以查看到数据库CPU,内存,会话等监控参数

[oracle 创建表空间]如何在控制台创建oracle表空间 三
点击“服务器”标签,在存储下点击“表空间”进入表空间管理界面


[oracle 创建表空间]如何在控制台创建oracle表空间 四
表空间管理界面可以对现有的数据库表空间进行编辑修改,删除。点击右上角“新建”按钮进入表空间创建窗口。名称里输入表空间名称。区管理里指定当前表空间是本地管理还是字典管理。指定表空间类型。您可以选择三个选项之一:“永久”(允许您另外设置一个选项,将表空间指定为默认永久表空间)、“临时”(允许您另外设置一个选项,将表空间指定为默认临时表空间)和“还原”(通过它可以选择将“还原保留时间保证”设置为“是”或“否”)。

[oracle 创建表空间]如何在控制台创建oracle表空间 五
点击下方“添加”按钮对数据库的存储空间进行配置。

[oracle 创建表空间]如何在控制台创建oracle表空间 六
在添加里输入表空间,路径,文件大小。数据文件已满后自动扩展(使您可以在数据文件已满时自动扩展数据文件大小的选项。如果选择此选项,则可以通过使用“增量”字段指定您希望增加的文件大小)增量(指定每次应用 AUTOEXTEND 选项时要添加到数据文件的容量增量大小),最大文件大小(指定使用 AUTOEXTEND 时文件的最大大小。可以选择将大小指定为无限制,也可以在值字段中输入一个值)

[oracle 创建表空间]如何在控制台创建oracle表空间 七
设置完存储后点击继续按钮回到表空间页面,然后点击“确定”按钮完成表空间的创建,表空间创建完毕后系统会在表空间里生成一条新的记录
