zoukankan      html  css  js  c++  java
  • undo管理

    undo segments的extents 的状态共有四种,free ,active , inacitve, expired  
    SQL> select SEGMENT_NAME,TABLESPACE_NAME,STATUS from  dba_undo_extents;


    SEGMENT_NAME                  TABLESPACE_NAME                STATUS
    ------------------------------ ------------------------------ ---------
    _SYSSMU10_3534552179$          UNDOTBS1                      EXPIRED
    _SYSSMU10_3534552179$          UNDOTBS1                      EXPIRED
    _SYSSMU10_3534552179$          UNDOTBS1                      UNEXPIRED
    _SYSSMU10_3534552179$          UNDOTBS1                      EXPIRED
    _SYSSMU10_3534552179$          UNDOTBS1                      EXPIRED
    _SYSSMU10_3534552179$          UNDOTBS1                      EXPIRED
    _SYSSMU9_3683992930$          UNDOTBS1                      EXPIRED
    _SYSSMU9_3683992930$          UNDOTBS1                      EXPIRED
    _SYSSMU9_3683992930$          UNDOTBS1                      EXPIRED

        1)free:没有分配给任何一个段
        2)active:区中有事务没有提交
        3)inactive:区中的事务提交了但是还没有达到  undo_retention 的时间
        4)expired:事务提交而且达到了undo_retention
        注:我们可以通过设定undo_retention来保住inactive的区,若没有free,则自动扩展;若扩展不了,则优先使用expired;若还不够,则就会使用inactive,但如果此时retention是guarantee保证的(也就是ALTER TABLESPACE undotbs1 RETENTION GUARANTEE),则无法使用inactive,会报ORA-30036。
    小结 :如果你倾向于保证数据一致性,也就是专注于查询,那么你有必要通过ALTER TABLESPACE undotbs1 RETENTION GUARANTEE,来保证一致性,也就是不管你空间够不够用,你都不可以使用inactive状态的区,这样就有可能导致由于没有可用的undo空间而导致数据库hang住,但是这样你可以保证查询语句执行时间在  undo_retention值 之内的所有查询 的一致性。如果你的业务倾向于事务,你可以不去设置  RETENTION GUARANTEE,这样当没有可用的undo空间时,可以去覆盖inactive状态的区,这样就有可能报错ora-01555,不能一致读了,因为你的undo_retention 值是通过咨询你们当前业务的查询语句执行时间最长的那个时间来确定的,也就是说undo_retention > sql执行最长时间,因此你使用不使用GUARANTEE取决于你业务的需求。

  • 相关阅读:
    HDU-6801 2020HDU多校第三场T11 (生成函数)
    [HDU-6791] 2020HDU多校第三场T1(回文自动机)
    回文自动机 (PAM,Palindrome Automaton)
    字符串的Period(周期),Border
    「APIO2019」路灯 (K-D Tree / 树套树 / CDQ + 树状数组)
    「APIO2019」桥梁(询问分块+并查集)
    「APIO2019」奇怪装置
    「APIO2018」选圆圈(K-D Tree/CDQ+Set)
    堆小结
    【[HNOI/AHOI2018]毒瘤】
  • 原文地址:https://www.cnblogs.com/elontian/p/7581512.html
Copyright © 2011-2022 走看看