iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >19_Oracle_Admin_调整表空间的大小
  • 946
分享到

19_Oracle_Admin_调整表空间的大小

2024-04-02 19:04:59 946人浏览 泡泡鱼
摘要

oracle数据库的存储设置可以分为三级:在全局范围内设置;在表空间层面设置;在segment层面设置。随着数据的增长,有的表空间可能已经快用完了;有的表空间则可能长期闲置,这就需要对表空间的大小进行调整,

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

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

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

19_Oracle_Admin_调整表空间的大小

 

19_Oracle_Admin_调整表空间的大小

 

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

 

一、自动增长,使用AUTOEXTEND

 

19_Oracle_Admin_调整表空间的大小

 

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

 

19_Oracle_Admin_调整表空间的大小

 

19_Oracle_Admin_调整表空间的大小

 

表DBA_DATA_FILES中存储了tablespace的体积

 

19_Oracle_Admin_调整表空间的大小

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

 

 

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

 

[oracle@localhostnotes]$ vim tablespace_usage.sql

SELECT 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设为自动增长=======

 

19_Oracle_Admin_调整表空间的大小

 

19_Oracle_Admin_调整表空间的大小

 

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 命令来手动调整;

 

19_Oracle_Admin_调整表空间的大小

 

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

 

 

 

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

 

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.

 

19_Oracle_Admin_调整表空间的大小

注意,临时表空间的数据文件信息储存在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的磁盘不能实现并发

 

19_Oracle_Admin_调整表空间的大小

 

 

 19_Oracle_Admin_调整表空间的大小

 

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

 

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

19_Oracle_Admin_调整表空间的大小

 

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

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

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


您可能感兴趣的文档:

--结束END--

本文标题: 19_Oracle_Admin_调整表空间的大小

本文链接: https://www.lsjlt.com/news/42904.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 19_Oracle_Admin_调整表空间的大小
    Oracle数据库的存储设置可以分为三级:在全局范围内设置;在表空间层面设置;在segment层面设置。随着数据的增长,有的表空间可能已经快用完了;有的表空间则可能长期闲置,这就需要对表空间的大小进行调整,...
    99+
    2022-10-18
  • Linux虚拟机空间怎么调整大小
    今天给大家介绍一下Linux虚拟机空间怎么调整大小。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。假设/dev/cobd3空间太小想变大,或变小官方提供的, 先...
    99+
    2023-06-28
  • Oracle查看表空间大小以及修改表空间大小
    Oracle查看表空间大小以及修改表空间大小问题描述:  1.修改表空间大小  2.查看表空间大小及相关的sql。一.修改表空间大小解决以上问题的办法:通过增大表空间即可解决,如下:使用...
    99+
    2022-10-18
  • 如何解决Oracle调整表空间大小ORA-03297错误问题
    这篇文章给大家分享的是有关如何解决Oracle调整表空间大小ORA-03297错误问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Oracle调整表空间大小—ORA-03297...
    99+
    2022-10-18
  • Linux调整Swap空间大小的扩容分区技巧
    查看当前Swap文件位置以及大小 要查看当前正在使用的swap文件或分区的位置,您可以使用swapon命令。 执行以下命令: sudo swapon --show 这将显示所有活动的swap空间,包括其类型(例如文件或分...
    99+
    2023-11-01
    Linux Swap 扩容 分区
  • Oracle查询表空间大小及每个表所占空间的大小语句示例
    目录1、查询数据库中所有的表空间以及表空间所占空间的大小,直接执行语句就可以了2、查看表空间物理文件的名称及大小3、查询所有表空间以及每个表空间的大小,已用空间,剩余空间,使用率和空闲率,直接执行语句就可以了4、查询某个...
    99+
    2022-12-19
    oracle 查看表空间文件大小 oracle如何查看用户的表空间 oracle查询表空间大小
  • wps表格大小如何调整
    这篇文章主要讲解了“wps表格大小如何调整”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“wps表格大小如何调整”吧!首先打开wps,然后新建打开一个表格。 之后点击左侧的开始,在右边选择“行...
    99+
    2023-07-02
  • oracle怎么查询表空间下表的大小
    要查询表空间下表的大小,可以使用以下SQL语句:```sqlSELECT owner, table_name, round(...
    99+
    2023-09-29
    oracle
  • oracle怎么修改表空间大小
    要修改Oracle表空间大小,可以按照以下步骤操作:1. 登录到Oracle数据库的系统用户,例如sys用户。2. 使用ALTER ...
    99+
    2023-08-30
    oracle
  • 如何评估undo表空间大小
    今天就跟大家聊聊有关如何评估undo表空间大小,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。如何估算Oracle数据库所需的UNDO表空间的大小:H...
    99+
    2022-10-19
  • oracle如何查询表空间大小
    oracle查询表空间大小步骤:一、使用数据库管理员账号登录到Oracle数据库;二、使用“SELECT”语句来查看空间列表;三、查询表空间大小有3种方法:1、使用dbms_utility包查询;2、使用dba_segments视图...
    99+
    2023-07-10
  • 怎么查询oracle表空间大小
    oracle查询表空间大小的方法:1、使用DBA_TABLESPACE视图,这个视图存储了所有表空间的信息,包括表空间的名称、大小、剩余可用空间等;2、使用Oracle提供的存储过程DBMS_SPACE.SPACE_USAGE,这个存储过程...
    99+
    2023-08-03
  • oracle表空间大小怎么查询
    oracle表空间大小查询的方法:1、SQL查询,通过执行SQL查询语句来获取表空间的大小信息;2、OEM,一个图形化的管理工具,可以用于管理和监控oracle数据库;3、Oracle SQL Developer,免费的集成开发环境,可以用...
    99+
    2023-08-07
  • Oracle中怎么查看表空间的大小
    这篇文章将为大家详细讲解有关Oracle中怎么查看表空间的大小,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。--1、查看表空间的名称及大小 SEL...
    99+
    2022-10-18
  • mysql怎么查看表空间剩余大小
    你可以使用以下语句来查看MySQL数据库中表空间的剩余大小:SELECT table_schema AS '数据库',Rou...
    99+
    2023-10-19
    mysql
  • oracle如何查看表空间剩余大小
    你可以使用以下语句来查看Oracle数据库中表空间的剩余大小:```sqlSELECT tablespace_name, r...
    99+
    2023-09-28
    oracle
  • MySQL怎么查看表占用空间大小
    这篇文章主要介绍“MySQL怎么查看表占用空间大小”,在日常操作中,相信很多人在MySQL怎么查看表占用空间大小问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL怎么查...
    99+
    2022-10-18
  • 数据库中如何查询表空间大小
    这篇文章主要为大家展示了“数据库中如何查询表空间大小”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“数据库中如何查询表空间大小”这篇文章吧。 ...
    99+
    2022-10-18
  • MySQL中怎么查看表占用空间大小
    今天就跟大家聊聊有关MySQL中怎么查看表占用空间大小,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码1,切换数据库use inform...
    99+
    2022-10-18
  • mysql如何实现查表空间大小的SQL语句
    这篇文章将为大家详细讲解有关mysql如何实现查表空间大小的SQL语句,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 SQL语句如下:sele...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作