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

2014-11-24 17:56:44 · 作者: · 浏览: 0

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


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


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#最小的日志组。