v$archived_log视图中,有关时间的几列的含义

v$archived_log视图中,有关时间的几列的含义:
first_time为该sequence#成为current redo log的时间
next_time为该sequence#被切换为archivelog 的开始时间
(即:该sequence#+1号成为current redo log的时间)
(即:在归档路径下,arch进程开始写入该sequence#的时间)
completion_time为该sequence#在归档路径下被arch进程写入完成的时间。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle数据库,可以通过查看数据库的redo日志来获取commit命令的执行时间。Redo日志是数据库事务的基础,它记录了所有修改数据库的操作,包括commit命令。 以下是查看commit命令执行时间的步骤: 1. 首先,使用v$session视图或者v$transaction视图,找到commit操作所在的会话或事务的ID。 例如,使用以下语句查找最近一次commit操作所在的会话ID: ``` SELECT SID, SERIAL#, LOGON_TIME FROM V$SESSION WHERE USERNAME = 'your_username' AND ROWNUM = 1 ORDER BY LOGON_TIME DESC; ``` 2. 使用v$log_history视图或v$archived_log视图来查找commit操作所在的日志文件。 例如,使用以下语句查找包含最近一次commit操作的日志文件: ``` SELECT FIRST_TIME, NEXT_TIME, NAME FROM V$ARCHIVED_LOG WHERE FIRST_TIME <= (SELECT MAX(TIME) FROM V$TRANSACTION) AND NEXT_TIME >= (SELECT MAX(TIME) FROM V$TRANSACTION); ``` 3. 找到对应的日志文件,使用LogMiner等工具来解析日志文件的信息,包括commit命令的执行时间。 例如,使用以下语句在当前数据库解析commit命令所在的日志文件: ``` BEGIN DBMS_LOGMNR.START_LOGMNR( STARTTIME => TO_DATE('2021-11-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS'), ENDTIME => TO_DATE('2021-11-02 00:00:00', 'YYYY-MM-DD HH24:MI:SS'), OPTIONS => DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG + DBMS_LOGMNR.CONTINUOUS_MINE ); END; ``` 以上是在当前数据库解析日志文件的方法,也可以使用LogMiner工具在外部解析日志文件。解析完成后,可以通过查询V$LOGMNR_CONTENTS视图获取commit命令的执行时间等信息。 注意,LogMiner的使用需要具备一定的权限和技术能力,建议在测试环境进行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值