Chinaunix首页 | 论坛 | 博客
  • 博客访问: 861574
  • 博文数量: 72
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 435
  • 用 户 组: 普通用户
  • 注册时间: 2013-04-27 20:07
个人简介

郭一军,网名guoyJoe,尖峰在线培训创始人、Oracle OCM、ITPUB论坛Oracle认证版版主、2013最佳精华贴、Senior DBA、Oracle OCT、 ACOUG MEMBER、CSDN 认证专家、RHCE、在线技术分享的倡导者和实践者。 http://www.jianfengedu.com http://jianfengedu.taobao.com

文章分类
文章存档

2014年(72)

分类: Oracle

2014-06-16 23:00:14

第1步修改undo表空间大小

create undo tablespace undotbs2 datafile '/u01/app/oracle/oradata/ocp/undotbs2.dbf' size 10M;
alter system set undo_tablespace=undotbs2;
 alter system set undo_retention=2 scope=both;

第2步、session1: 目标是让b表报快照过旧的报错
   conn gyj/gyj
    create table a (id int,cc varchar2(10));
    insert into a values(1,'hello');
    commit;
     create table b(id int,cc varchar2(10));
    insert into b values(10,'AAAAAA');
    commit;
select * from a;
select * from b;
var x refcursor;
exec open :x for select * from b;

第3步、session2:修改b表,字段cc前镜像"OK"保存在UDNO段中
   update b set cc='BBBBBB' where id= 10;
   commit;

第4步、session 3:该条语句就是刷新缓存
  conn / as sysdba
SQL> alter session set events = 'immediate trace name flush_cache'; --9i提供强制刷缓存
     (alter system flush buffer_cache;--10g提供的一种刷缓存方法)

第5步、 session2: 在A表上行大的事务,多运行几次以确保,回滚段被覆盖
begin
   for i in 1..20000 loop
    update a set cc='HELLOWWWW';
    commit;
   end loop;
  end;
/

第6步、session 1:在B表上执行查询(第一步的查询)
SQL> print :x
ERROR:

ORA-01555: snapshot too old: rollback segment number 21 with name "_SYSSMU21$" too small


 


**********本博客所有内容均为原创,如有转载请注明作者和出处!!!**********
Name:    guoyJoe

QQ:        252803295

Email:    oracledba_cn@hotmail.com

Blog:      http://blog.csdn.net/guoyJoe

ITPUB:   http://www.itpub.net/space-uid-28460966.html

OCM:    

阅读(2165) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~