视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle10g中system回滚段的作用
2020-11-09 12:01:18 责编:小采
文档


在Oracle10g中依然存在一个回滚段,名叫system,它是有Oracle在创建数据库的时候创建的,并且这个回滚段存在于SYSTEM表空间中。它

在Oracle10g中依然存在一个回滚段,名叫system,它是有Oracle在创建数据库的时候创建的,并且这个回滚段存在于SYSTEM表空间中。它存在的目的就是为了回滚系统事物,也就是说数据字典修改之后的镜像就存在于system回滚段。

SQL> select segment_name,owner,tablespace_name,segment_id,file_id from dba_rollback_segs where segment_id=0;

SEGMENT_NAME OWNER TABLESPACE_NAME SEGMENT_ID FILE_ID

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

SYSTEM SYS SYSTEM 0 1

我们查询dba_rollback_segs这个视图就可以得到系统中回滚段/撤销段信息

为了探究system回滚段的作用,我做如下实验:

首先在一个session中创建一个测试表,然后运行一个过程,批量插入1百万条数据

SQL> create table test(data varchar2(100));

表已创建。

SQL> begin

2 for v_loop in 1 ..1000000 loop

3 insert into test values('test!');

4 commit;

5 end loop;

6 end;

7 /

PL/SQL 过程已成功完成。

同时在另外一个session中运行下面的脚本

SQL> declare

2 v_cnt int :=0;

3 begin

4 for v_loop in 1 ..1000000 loop

5 select count(*) into v_cnt from v$transaction where xidusn=0;---xidusn表示rollback segment_id

6 if v_cnt>0 then

7 dbms_output.put_line('Find it');

8 end if;

9 end loop;

10 end;

11 /

Find it

Find it

Find it

Find it

....省略之...................

由此实验得出system回滚段依然会被系统利用,同时得出v$transaction视图也记录后台进程的事物

system回滚段是用了记录Oracle内部操作的,也就是数据字典更改。

看见某本书上面写system回滚段在Oracle创建之后,,就永远不会被使用,恩其实是错误的.

下载本文
显示全文
专题