• 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/
  • 相关阅读:
    OC与JS交互之WKWebView
    iOS下JS与OC互相调用(三)--MessageHandler
    html base64 img 图片显示
    Vue中img的src属性绑定与static文件夹
    XML 树结构
    XML 用途
    XML 简介
    JS Window对象
    JS Math对象
    JS 字符串操作
  • 原文地址:https://www.cnblogs.com/tianlesoftware/p/3609812.html
Copyright © 2020-2023  润新知