zoukankan      html  css  js  c++  java
  • How to map SCN with Timestamp before 10g [ID 365536.1]

    How to map SCN with Timestamp before 10g? [ID 365536.1]


     

    Modified 16-MAY-2006     Type HOWTO     Status PUBLISHED

     

    In this Document
      Goal
      Solution


    Applies to:

    Oracle Server - Enterprise Edition - Version: 9.2.0.6.0
    Information in this document applies to any platform.

    Goal

    In this note, we will help Database Administrators with answers to two common questions:
    How can I know the time of last transaction (time of last SCN)?
    How can I map SCN with Timestamp prior to 10g?

    Solution

    SCN <-> TIMESTAMP conversion features are available only from Oracle 10g.  In 10g, there are two built-in functions to give the timestamp and SCN mapping details--Timestamp_to_scn() and Scn_to_timestamp().

    For example: In 10g, you will issue code like,

    SQL> select current_scn from v$database;
    CURRENT_SCN
    ---------------------------
    1086382

    SQL> Select scn_to_timestamp(1086382) from dual;

    SCN_TO_TIMESTAMP(1086382)
    ---------------------------------------------------------------------------
    15-DEC-05 09.39.49.000000000 PM

    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    However, in earlier releases, while there is a system object - SYS.SMON_SCN_TIME that will provide the SCN to TIME mapping information.   There is no conversion facility provided. 

    SYS.SMON_SCN_TIME will have a maximum of 1440 rows and each record will be for a 5 minute period.  Oracle maintains this information for maximum of 5 days after which the records will be recycled.

    This means that data is stored 12 times per hour * 24 hours * 5 days=1440 rows. 

    SCN value is stored internally as :
    i. SCN_wrap
    ii. SCN_base

    Whenever the SCN is incremented, the BASE component is incremented first unil it reaches it maximum.  Once the BASE reaches the maximum value allowed, it is initialized to zero again after incrementing the WRAP by 1.

    Using this logic, we can calculate the timestamp of the SCN as follows:

    (SCN_WRP * 4294967296) + SCN_BAS should give us the SCN in the number format

    To get the time/date for an SCN value in 9i, use the following example:
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    -- (a) Get the current SCN base.
    SQL>select max(scn_bas) SCN_BASE from smon_scn_time;

    1603342197

    --(b) Get the complete SCN and the timestamp.

    SQL> alter session set NLS_DATE_FORMAT='DD-MON-YY HH:MI:SS';

    SQL> select time_dp TIMESTAMP, scn_wrp*4294967296+SCN_bas SCN from smon_scn_time where
    scn_bas='1603342197';

    TIMESTAMP                 SCN
    ------------------            ----------
    28-JUL-06 05:31:08        8252235517813


     

     

     

     

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

    Blog http://blog.csdn.net/tianlesoftware

    网上资源: http://tianlesoftware.download.csdn.net

    相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx

    DBA1 群:62697716(); DBA2 群:62697977()

    DBA3 群:62697850   DBA 超级群:63306533;    

    聊天 群:40132017

    --加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请

    道森Oracle,国内最早、最大的网络语音培训机构,我们提供专业、优质的Oracle技术培训和服务! 我们的官方网站:http://www.daosenoracle.com 官方淘宝店:http://daosenpx.taobao.com/
  • 相关阅读:
    第十九节 集群模式内各节点的通信和文件拷贝
    第十八节 虚拟机克隆后ip修改
    WAF 与 RASP 的安装使用大比拼!
    不改变中间层,如何玩转 .NET 的远程处理功能?
    什么是实时应用程序自我保护(RASP)?
    拒绝「技术栈」选择恐惧症
    为什么Nagios会那么吵?你又能做些什么呢?(1)
    Java 应用发布后,需要关注的7个性能指标
    玩转AWS CloudWatch微信告警
    日均百万 PV 的站点如何做性能监测?试试「3M口罩」!
  • 原文地址:https://www.cnblogs.com/tianlesoftware/p/3609813.html
Copyright © 2011-2022 走看看