oracle表空间调整大小,19_Oracle_Admin_调整表空间的大小

Oracle数据库的存储设置可以分为三级:在全局范围内设置;在表空间层面设置;在segment层面设置。

随着数据的增长,有的表空间可能已经快用完了;有的表空间则可能长期闲置,这就需要对表空间的大小进行调整,,其方式主要有以下几种:

1. 设置为自动增长; 2. 使用ALTER命令手动调整;3. 通过增加Datafile来扩充表空间; 4. 直接增加表空间

72a45dcf5e1557fa2ac4a63a1c8009e9.png

edec6c004d85222d9563ad6e0d359f55.png

ALTERR TABLESPACE的方式是针对datadictionary里的修改,不值得推荐,如有兴趣可以查阅联机文档中的相关内容。

一、自动增长,使用AUTOEXTEND

8f247b9745f58cce3bc8da5c545edf19.png

只能自动增大,可以在创建表空间或创建数据库时设定,凡是有DATAFILE的语句,都可以设定NEXT和MAXSIZE值。

27668efcc670153358558316785d3094.png

a0816c4953b7dcc55a725f098d79d46b.png

表DBA_DATA_FILES中存储了tablespace的体积

52e2961b3bd1c6cb9e128349ac6cf41d.png

DBA_FREE_SPACE存储了已经用掉的tablespace的体积

/*演示设定表空间自动增长*/

============查询剩余表空间============

[oracle@localhostnotes]$ vim tablespace_usage.sqlSELECT a.tablespace_name, a.bytes bytes_used, b.largest, round(((a.bytes- b.bytes)/a.bytes)*100,2) percent_used

FROM

(SELECT tablespace_name, sum(bytes) bytes FROM dba_data_files GROUP BYtablespace_name) a,

(SELECT tablespace_name, sum(bytes) bytes, max(bytes) largest FROMdba_free_space GROUP BY tablespace_name) b

WHERE a.tablespace_name = b.tablespace_name

ORDER BY ((a.bytes - b.bytes) / a.bytes) DESC;

-- 数据库中并没有直接提供剩余表空间大小的表和相关数值,

-- 所以可以通过网络搜索一些剩余表空间的query语句

SQL> @notes/tablespace_usage.sql

TABLESPACE_NAME               BYTES_USED    LARGEST PERCENT_USED

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

SYSTEM                         723517440    3145728        99.52

SYSAUX                         671088640   34603008        94.73

USERS                            5242880     458752        88.75

EXAMPLE                        104857600   19726336        78.44

UNDOTBS1                        57671680   29360128        32.27

WILEY                           20971520   19660800         5.63

-- 可以看到wiley这个表空间还有比较多的剩余空间

-- 而SYSTEM 和SYSAUX等表空间已经快用完了,因此需要对其进行扩容

6 rows selected.

=====为wiley表空间扩容======

SQL> alter tablespace wiley add datafile

2 '/oracle/oradata/orcl/wiley2.dbf' size 20M

3  autoextend on next 10M maxsize100M;Tablespace altered.

=======再次查看剩余表空间=====

SQL> @notes/tablespace_usage.sql

TABLESPACE_NAME                BYTES_USED    LARGEST PERCENT_USED

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

SYSTEM                          723517440    3145728        99.52

SYSAUX                          671088640   34603008        94.73

USERS                             5242880     458752        88.75

EXAMPLE                         104857600   19726336        78.44

UNDOTBS1                        57671680   29360128        32.27

WILEY                            41943040   19922944         5.31

-- 可以看得表空间wiley的体积增加了20M

6 rows selected.

======查看表空间的autoextend属性是否为enable的=====

SQL> desc dba_data_files;Name                                      Null?   Type

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

FILE_NAME                                         VARCHAR2(513)

FILE_ID                                           NUMBER

TABLESPACE_NAME                                    VARCHAR2(30)

BYTES                                             NUMBER

BLOCKS                                            NUMBER

STATUS                                            VARCHAR2(9)

RELATIVE_FNO                                       NUMBER

AUTOEXTENSIBLE                                    VARCHAR2(3)

-- 表明是否可以增长

MAXBYTES                                          NUMBER

MAXBLOCKS                                         NUMBER

INCREMENT_BY                                       NUMBER

USER_BYTES                                         NUMBER

USER_BLOCKS                                        NUMBER

ONLINE_STATUS                                     VARCHAR2(7)

SQL>col FILE_NAME format a40

SQL>col TABLESPACE_NAME format a20

SQL>select file_name, tablespace_name, autoextensible from dba_data_files;FILE_NAME                               TABLESPACE_NAME      AUT

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

/oracle/oradata/orcl/users01.dbf        USERS                YES

/oracle/oradata/orcl/undotbs01.dbf      UNDOTBS1             YES

/oracle/oradata/orcl/sysaux01.dbf       SYSAUX               YES

/oracle/oradata/orcl/system01.dbf       SYSTEM               YES

/oracle/oradata/orcl/example01.dbf      EXAMPLE              YES

/oracle/oradata/orcl/mickey01.dbf       MICKEY               NO

/oracle/oradata/orcl/wiley.dbf          WILEY                NO

-- 表空间wiley的第一个data file wiley不能自动增长的

/oracle/oradata/orcl/wiley2.dbf         WILEY                YES

-- 表空间wiley的第二个data file wiley2 可以自动增长

8 rows selected.

======将原有设为不自动增长的datafile设为自动增长=======

3103886aa6b17411ee2e1b18cd109977.png

d72895d8fed1d2246adf930a2d87f825.png

SQL> alter database datafile

2 '/oracle/oradata/orcl/wiley.dbf'

3  autoextend on next 10M maxsize100M;Database altered.

SQL> select file_name, tablespace_name,autoextensible from dba_data_files;FILE_NAME                               TABLESPACE_NAME      AUT

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

/oracle/oradata/orcl/users01.dbf         USERS                YES

/oracle/oradata/orcl/undotbs01.dbf       UNDOTBS1             YES

/oracle/oradata/orcl/sysaux01.dbf        SYSAUX               YES

/oracle/oradata/orcl/system01.dbf        SYSTEM               YES

/oracle/oradata/orcl/example01.dbf       EXAMPLE              YES

/oracle/oradata/orcl/mickey01.dbf        MICKEY               NO

/oracle/oradata/orcl/wiley.dbf           WILEY                YES

-- 已经更改为自动增长了。

/oracle/oradata/orcl/wiley2.dbf          WILEY                YES

8 rows selected.

二、使用ALTER命令来手动调整;

10f92d10ff799e1a593aa45375e618b3.png

如果一个数据文件原来使用了100M,现在将其resize到200M,是可行的;但如果一个数据文件原来已经使用了300M,再将其resize到200M,则会失败。

/*演示使用ALTER命令手动调整表空间*/

=======查询现有表空间信息=======

SQL> select file_name, tablespace_name,bytes from dba_data_files;FILE_NAME                               TABLESPACE_NAME           BYTES

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

/oracle/oradata/orcl/users01.dbf        USERS                   5242880

/oracle/oradata/orcl/undotbs01.dbf      UNDOTBS1               57671680

/oracle/oradata/orcl/sysaux01.dbf       SYSAUX                587202560

/oracle/oradata/orcl/system01.dbf       SYSTEM                713031680

/oracle/oradata/orcl/example01.dbf      EXAMPLE               104857600

/oracle/oradata/orcl/mickey01.dbf       MICKEY                 20971520

/oracle/oradata/orcl/wiley.dbf          WILEY                  20971520

/oracle/oradata/orcl/wiley2.dbf         WILEY                  20971520

8 rows selected.

200287ac9c1970292457020bb715b0e9.png

注意,临时表空间的数据文件信息储存在dba_temp_files这个表中。

======调整表空间wiley的数据文件wiley2为10M======

SQL> alter database datafile

2 '/oracle/oradata/orcl/wiley2.dbf'

3  resize 10M;

Database altered.

SQL> select file_name, tablespace_name,bytes from dba_data_files;

FILE_NAME                                TABLESPACE_NAME           BYTES

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

/oracle/oradata/orcl/users01.dbf        USERS                   5242880

/oracle/oradata/orcl/undotbs01.dbf      UNDOTBS1               57671680

/oracle/oradata/orcl/sysaux01.dbf       SYSAUX                671088640

/oracle/oradata/orcl/system01.dbf       SYSTEM                723517440

/oracle/oradata/orcl/example01.dbf      EXAMPLE               104857600

/oracle/oradata/orcl/wiley.dbf          WILEY                  20971520

/oracle/oradata/orcl/wiley2.dbf         WILEY                  10485760

--  数据文件wiley2的大小已经调整为10M了

7 rows selected.

注意,将data file的体积调小在很多情况下会失败。

SQL> alter database datafile

2 '/oracle/oradata/orcl/example01.dbf'

3  resize 10M;alter database datafile

*

ERROR at line 1:

ORA-03297: file contains used data beyond requested RESIZEvalue

-- 提示调整的体积小于现有文件大小。

三、通过增加数据文件的方式来扩充表空间。

通常情况下10个10G的data file组成的磁盘比起一个100G的data file性能更优,因为100G的磁盘不能实现并发。

c03765adccc73d1e9ef696c92c565449.png

d95d44e52da972560a811949df1aad37.png

增加data file使用的是ALTER TABLESPACE,而不是ALTER DATABASE,建议在实际操作之前,先查询联机文档。

四、直接增加一个新的表空间。

4ca013f29ed2f62cf6488b436aade8a6.png

在调整表空间的体积之前,可以先查询一下表空间的大小。表空间实际上是数据库内部的逻辑概念,操作系统无法通过具体的命令来查看其体,但可以通过查询数据字典来统计其使用的百分比。

在联机文档REFERENCE中查询数据字典的相关章节,可以获取表空间的信息。

直接创建表空间的方法前文中已经介绍过了,此处不加赘述。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值