扩大或缩小undo表空间
***********************************************声明***********************************************************************
原创作品。出自 “深蓝的blog” 博客,欢迎转载,转载时请务必注明出处,否则追究版权法律责任。
深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/39935157
****************************************************************************************************************************
实验项目:将undo表空间扩大,然后缩小
SQL> select name,bytes/1024/1024 M from v$datafile;
--查询undo表空间,当前为230m
NAME M
-------------------------------------------------- ----------
/u01/app/oracle/oradata/xcky/system01.dbf 760
/u01/app/oracle/oradata/xcky/sysaux01.dbf 550
/u01/app/oracle/oradata/xcky/undotbs01.dbf 230
/u01/app/oracle/oradata/xcky/users01.dbf 1518.75
/u01/app/oracle/oradata/xcky/example01.dbf 330
(1)、扩展undo表空间
思路:创建一个更大的undo表空间。让后将原undo空间替换
SQL> create undo tablespace undotbs02 datafile '/u01/app/oracle/oradata/xcky/undotbs02.dbf' size 500m reuse
autoextend on;
Tablespace created.
SQL> alter system set undo_tablespace=undotbs02;
System altered.
SQL> select name,bytes/1024/1024 M from v$datafile;
--查询会发现,新扩展的undo表空间
NAME M
-------------------------------------------------- ----------
/u01/app/oracle/oradata/xcky/system01.dbf 760
/u01/app/oracle/oradata/xcky/sysaux01.dbf 550
/u01/app/oracle/oradata/xcky/undotbs01.dbf 230
/u01/app/oracle/oradata/xcky/users01.dbf 1518.75
/u01/app/oracle/oradata/xcky/example01.dbf 330
/u01/app/oracle/oradata/xcky/undotbs02.dbf 500
SQL> select tablespace_name,sum(bytes)/1024/1024 mb from dba_free_space group by tablespace_name;
--查找出之前undo表空间的名字
TABLESPACE_NAME MB
------------------------------ ----------
BULLETIN_INFO 499
INDEX_EIS 19
SYSAUX 33
UNDOTBS1 204.375
TBS_XZXT_PHOTO 19
TBS_XZXT_SYSTEM 19
VIEW_LOG 99
UNDOTBS02 497.75
......
SQL> drop tablespace UNDOTBS1 including contents and datafiles;
--删除undo表空间
Tablespace dropped.
SQL> select tablespace_name,sum(bytes)/1024/1024 mb from dba_free_space group by tablespace_name;
--再次查看undo表空间已经为新扩展的undo表空间了
TABLESPACE_NAME MB
------------------------------ ----------
BULLETIN_INFO 499
INDEX_EIS 19
SYSAUX 33
VIEW_LOG 99
UNDOTBS02 497.75
(2)、缩小undo表空间
思路:有了之前扩展undo表空间的方法,接下来缩小表空间便会变得简单了。原理一样,创建一个小的undo表空间,然后把大的undo表空间删除就可以。
SQL> create undo tablespace UNDOTBS1 datafile '/u01/app/oracle/oradata/xcky/undotbs01.dbf' size 250m reuse autoextend
on;
--创建一个小的undo表空间
Tablespace created.
SQL> alter system set UNDO_TABLESPACE=UNDOTBS1;
--改变undo表空间为UNDOTBS1
System altered.
SQL> select tablespace_name,sum(bytes)/1024/1024 mb from dba_free_space group by tablespace_name;
--再次查询,新建的undo表空间已经显示
TABLESPACE_NAME MB
------------------------------ ----------
BULLETIN_INFO 499
INDEX_EIS 19
SYSAUX 33
UNDOTBS1 247.75
UNDOTBS02 497.75
SQL> drop tablespace UNDOTBS02 including contents and datafiles;
--删除大的undo表空间
Tablespace dropped.
SQL> select tablespace_name,sum(bytes)/1024/1024 mb from dba_free_space group by tablespace_name;
--查看表空间情况。已经完毕了缩小undo表空间
TABLESPACE_NAME MB
------------------------------ ----------
BULLETIN_INFO 499
INDEX_EIS 19
SYSAUX 33
UNDOTBS1 247.75
结合以上实验过程。编写脚本,能够减轻日后的工作量,有了上面的基础,看懂以下的语句应该是so easy了吧,O(∩_∩)O哈哈~
指令例如以下:
脚本实现:
[root@xckydb soft]# vi query_undo.sql
--编写undo表空间查询脚本
SELECT a.name, b.name
FROM v$tablespace a, v$datafile b
WHERE a.name = (SELECT VALUE
FROM v$parameter
WHERE name = 'undo_tablespace')
AND a.ts# = b.ts#;
SQL> @/soft/query_undo.sql
NAME NAME
------------------------------ ------------------------------
UNDOTBS1 /u01/app/oracle/oradata/xcky/u
ndotbs01.dbf
[root@xckydb soft]# vi create_undo.sql
--编写undo表空间创建脚本
#create middle undo tablespace
Create UNDO TABLESPACE UNDOTBS2 DATAFILE <'/undotbs02.dbf'> SIZE <100M> REUSE AUTOEXTEND ON;
Alter SYSTEM SET UNDO_TABLESPACE=UNDOTBS2;
#delete old undo tablespace
Drop TABLESPACE <UNDOTBS1> INCLUDING CONTENTS AND DATAFILES;
Select * FROM DBA_TABLESPACES;
#create new undo tablespace
Create UNDO TABLESPACE <UNDOTBS1> DATAFILE <'/undotbs01.dbf'> SIZE <100M> REUSE AUTOEXTEND ON;
Alter SYSTEM SET UNDO_TABLESPACE=UNDOTBS1;
#delete middle undo tablespace
Drop TABLESPACE UNDOTBS2 INCLUDING CONTENTS AND DATAFILES;
Select * FROM DBA_TABLESPACES;
***********************************************声明***********************************************************************
原创作品,出自 “深蓝的blog” 博客。欢迎转载,转载时请务必注明出处,否则追究版权法律责任。
深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/39935157
****************************************************************************************************************************
版权声明:本文博主原创文章,博客,未经同意不得转载。
扩大或缩小undo表空间的更多相关文章
- MySQL 5.7新特性之在线收缩undo表空间
1. MySQL 5.5时代的undo log 在MySQL5.5以及之前,大家会发现随着数据库上线时间越来越长,ibdata1文件(即InnoDB的共享表空间,或者系统表空间)会越来越大,这会造成2 ...
- 如何删除回滚段状态为NEEDS RECOVERY的undo表空间
环境:RHEL 6.4 + Oracle 11.2.0.4 背景:备份恢复的测试库在一次不完全恢复后,没有来及做有效的全备,又一次数据库故障导致数据库无法正常open. 只能离线部分数据文件打开数据库 ...
- 记一次ORACLE的UNDO表空间爆满分析过程
这篇文章是记录一次ORACLE数据库UNDO表空间爆满的分析过程,主要整理.梳理了同事分析的思路.具体过程如下所示: 早上收到一数据库服务器的UNDO表空间的告警邮件,最早一封是7:55发出的(监控作 ...
- Oracle 11gR2 Database UNDO表空间使用率居高不下-转载
客户的数据库是Oracle Database 11.2.0.3.0 for AIX 6.1 64bit的单机数据库.客户查询DBA_FREE_SPACE发现UNDO表空间的使用率高达98%以上.客户的 ...
- UNDO表空间设置
flashback query和flashback table都是以用UNDO表空间的内容来进行恢复数据 查看undo内容保存的时间: SQL> show parameter undo_re N ...
- UNDO表空间损坏,爆满,ORA-600[4194]/[4193]错误解决
模拟手工删除UNDO表空间 在ORADATA 中把UNDOTBS01.DBF 删除 模拟启库 SQL> STARUP; * 第 1 行出现错误: ORA-01157: 无法标识/锁定数据文件 2 ...
- oracle表空间查询维护命令大全之二(undo表空间)
--undo表空间汇总 --查看全部的表空间名字 select name from v$tablespace; --创建新的UNDO表空间,并设置自己主动扩展參数; create undo table ...
- Oracle数据库 ORA-01555 快照过旧 (undo表空间:撤销表空间)
UNDO表空间用于存放UNDO数据,当执行DML操作时,oracle会将这些操作的旧数据写入到UNDO段,以保证可以回滚或者一致读等,而临时表空间主要用来做查询和存放一些缓冲区数据.你听说UNDO也是 ...
- undo表空间
undo表空间undo表空间的管理,主要包括创建.删除.修改.切换.其中需要注意的是不能在undo表空间创建数据库对象,还有就是只能是单文件或大文件表空间. 创建创建主要有两种方法,一种是在创建数据库 ...
随机推荐
- Umbraco扩展开发
国内Umbraco方面的资料很少,搜集到一些国外的优秀项目或插件.记录下来,便于日后使用: backoffice:https://github.com/TimGeyssens 后台扩展UI,可以在这里 ...
- Cortex-M3学习日志(三)-- 外部中断0
无论是哪款单片机应该都有对应的中断的功能,中断在嵌入式系统的地位毋庸置疑.LPC1768微处理器包括4个外部中断,分别是EINT0.EINT1.EINT2.EINT3对应的引脚分别是P2.10~P2. ...
- Android Activity 的四种启动模式 lunchMode 和 Intent.setFlags();singleTask的两种启动方式。
原文:Android Activity 的四种启动模式 lunchMode 和 Intent.setFlags();singleTask的两种启动方式. Android Activity 的四种启动模 ...
- shell学习笔记
shell学习笔记 .查看/etc/shells,看看有几个可用的Shell . 曾经用过的命令存在.bash_history中,但是~/.bash_history记录的是前一次登录前记录的所有指令, ...
- discuz函数dgmdate
function dgmdate($timestamp, $format = 'dt', $timeoffset = '9999', $uformat = '') { global $_G; $for ...
- c reference
1,函数:strdup复制字符串函数原型定义:char * strdup(const char *s);函数说明:strdup()会先用maolloc()配置与参数s字符串相同的空间大小,然后将参数s ...
- 三点顺序_nyoj_68(计算几何).java
三点顺序 时间限制: 1000 ms | 内存限制: 65535 KB 难度: 3 描述 现在给你不共线的三个点A,B,C的坐标,它们一定能组成一个三角形,现在让你判断A,B,C是顺时针给出的 ...
- cors技术
简称跨域资源共享: 若是配置nodejs: 需在公共路由添加三句话:代码如下: // 全局头设置 app.all('*', function(req, res, next) { res.set({ ' ...
- Phalcon 调试应用程序
调试应用程序(Debugging Applications)¶ Phalcon中提供了提供了几种调试级别即通知,错误和异常. 异常类 Exception class 提供了发生错误时的一些经常使用的调 ...
- sql存储过程的简单使用
存储过程(Stored Procedure)是数据库系统中,一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它. 创建 ...