Welcome 微信登录

首页 / 数据库 / MySQL / 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的42SQL> 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下备份MySQL数据库Shell脚本以及PHP脚本Oracle sqlplus设置显示格式命令详解相关资讯      oracle 
  • [INS-32052] Oracle基目录和Oracle  (07/22/2014 07:41:41)
  • Oracle 4个大对象(lobs)数据类型  (02/03/2013 12:33:05)
  • Oracle按时间段分组统计  (07/26/2012 10:36:48)
  • [Oracle] dbms_metadata.get_ddl的  (07/12/2013 07:37:30)
  • Liferay Portal 配置使用Oracle和  (07/31/2012 20:07:18)
  • Concurrent Request:Inactive   (07/20/2012 07:44:05)
本文评论 查看全部评论 (0)
表情: 姓名: 字数