>  기사  >  데이터 베이스  >  Oracle 如何决定日志切换到剩下的那个日志组

Oracle 如何决定日志切换到剩下的那个日志组

WBOY
WBOY원래의
2016-06-07 16:58:28931검색

我们知道,当前在线日志被写满的时候,或者达到某些条件,或者人为切换日志时,oracle就会发生日志切换工作,即使当前在线日志组

我们知道,当前在线日志被写满的时候,或者达到某些条件,或者人为切换日志时,Oracle就会发生日志切换工作,即使当前在线日志组从这个日志组到另外一个日志组,实现日志的循环机制。那么oracle怎么决定下一个当前在线日志组是剩下中的哪一个日志组呢?

做了一个简单小实验,可以说明这个问题。

我们首先来看看,当然日志组的情况:

SQL> select GROUP#,SEQUENCE#,ARCHIVED,STATUS from v$log;

    GROUP#  SEQUENCE# ARC STATUS

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

         1         44 YES ACTIVE

         2         45 NO  CURRENT

         3         43 YES INACTIVE

然后,我们clear日志组1,好让它的sequence#小于当前日志组3的42

SQL> alter database clear unarchived logfile group 1;

数据库已更改。

SQL> select GROUP#,SEQUENCE#,ARCHIVED,STATUS from v$log;

    GROUP#  SEQUENCE# ARC STATUS

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

         1          0 YES UNUSED

         2         45 NO  CURRENT

         3         43 YES INACTIVE

之后,,我们切换当前日志组,看看发生什么情况?

SQL> alter system switch logfile;

系统已更改。

SQL> select GROUP#,SEQUENCE#,ARCHIVED,STATUS from v$log;

    GROUP#  SEQUENCE# ARC STATUS

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

         1         46 NO  CURRENT

         2         45 YES ACTIVE

         3         43 YES INACTIVE

最后,我们再次的切换一次日志,更加证明我们的猜测:

SQL> alter system switch logfile;

系统已更改。

SQL> select GROUP#,SEQUENCE#,ARCHIVED,STATUS from v$log;

    GROUP#  SEQUENCE# ARC STATUS

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

         1         46 YES ACTIVE

         2         45 YES ACTIVE

         3         43 NO  CURRENT

从上面这个实验,我们可以轻松的看到oracle日志切换时,选择下一个当前日志组的规律,就是:总是切换到剩下的日志组中log sequence#最小的日志组。

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.