Oracle 19c怎么缩减UNDO表空间和容量

开发技术 作者:chen 2024-03-30 02:00:01
本篇内容主要讲解“Oracle 19c怎么缩减UNDO表空间和容量”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle...

本篇内容主要讲解“Oracle 19c怎么缩减UNDO表空间和容量”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle 19c怎么缩减UNDO表空间和容量”吧!

1、创建一个新的 UNDO 表空间,并将其指定为当前 UNDO 表空间;

SQL> CREATE UNDO TABLESPACE UNDO_TBS DATAFILE '+DATA' SIZE 1G;

SQL> ALTER SYSTEM SET undo_tablespace=UNDO_TBS;

在事务两比较大的系统中,指定新UNDO表空间后可能会导致整个数据库无法做任何更改操作,任何的 DDL或者DML操作都会报错,这时如果允许的话可以重启数据库来解决。数据库重启之后,刚刚更改的系统默认UNDO表空间参数会失效,还是使用的旧的,应该在 NOMOUNT 状态下重新指定新的 UNDO表空间,然后再打开数据库继续做下面的操作;

2、删除 原 UNDO 表空间(一般是 UNDOTBS1);

SQL> DROP TABLESPACE UNDOTBS1 INCLUDING CONTENTS AND DATAFILES;

3、创建一个新的跟原来 UNDO 表空间同名的 UNDO 表空间(UNDOTBS1),并将其指定为当前 UNDO 表空间,删除第一步创建的  UNDO 表空间;

SQL> CREATE UNDO TABLESPACE UNDOTBS1 DATAFILE '+DATA' SIZE 200M AUTOEXTEND ON;

SQL> ALTER SYSTEM SET undo_tablespace=UNDOTBS1;

SQL> DROP TABLESPACE UNDO_TBS INCLUDING CONTENTS AND DATAFILES;

注意:整个过程中是不需要重启数据库的,如果重启了数据库,参数 undo_tablespace 又会变成默认值(UNDOTBS1),所以我们最后的 UNDO 表空间还是叫 UNDOTBS1 这个名字。
Oracle

Oracle 19c 中 UNDO 表空间是独立的,CDB 和 每个PDB 都有自己的 UNDO 表空间,因此实际操作跟 11g 是一样的。这里可以看到有3个 UNDOTBS1 表空间,分别属于不同的 CON_ID。

Oracle

到此,相信大家对“Oracle 19c怎么缩减UNDO表空间和容量”有了更深的了解,不妨来实际操作一番吧!这里是捷杰建站网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_2302.html
oracle