<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      302 隨筆 :: 26 文章 :: 82 評論 :: 0 Trackbacks
    ??? 改變Synonym的定義,會使涉及到的objects的status變成invalid,但是9i跟10g還是有區別。另外簡單的object在INVALID之后下一次查詢時即可自動編譯,但也有些會造成一些影響。具體Oracle定期Recompiling的方法有很多,可以直接google一下,Oracle自帶也有腳本,例如:...\oracle\ora92\rdbms\admin\utlirp.sql
    ?
    ??? 摘錄一下ask tom的內容

    January 02, 2006
    Jim -- Thanks for the question regarding "Synonym runtime swithing", version 9.2.0
    You Asked
    						
    								My client has two tables that are identical other then name, I'll call them T1 
    and T2.
    One synonym, TN that points to T1, while some batch process works on T2.
    When the batch is completed the synonym TN is dropped and recreated pointing to 
    the T2 table. 
    This switch takes place back and forth several times a day causing some unknown 
    behavior.
    
    My questions are:
    1) Are all objects that reference the synonym TN invalided during the drop 
    and recreation? And recompiled once accessed? 
    2) If a session is working, running a long query using the TN synonym 
    during the drop and recreate, what happens to that session?
    3) Can you outline the work flow of what takes place during the process of 
    switching the synonym at runtime for both existing and new sessions making 
    requests using the TN synonym
    
    I don't like the switching aspect myself, but need to get some facts on the 
    process.
    
    
    						

    and we said...
    						
    								1) in 9i, if you "create or replace synonym T for T1" and later "create or 
    replace synonym T for T2" - all referencing PLSQL is invalidated, all 
    referencing views are invalidated, all referencing parsed SQL in the shared 
    pool is invalidated.
    
    They will be recompiled automatically upon their next reference
    
    In 10g, all referencing parsed SQL in the shared pool is invalidated - but NOT 
    plsql and NOT views.
    
    
    2) the query should run to completion.  However, if it is a procedure running 
    that long running query and the query is static sql and hence the procedure is 
    invalid - no one can run it until the procedure is finished running (because no 
    one can compile it).
    
    3) see #1.
    
    
    I would strongly recommend 10g for this switch back and forth - but bear in 
    mind that create or replace synonym will invalidate all SQL that references it 
    regardless (burst of hard parse everytime you do this) 
    						

    Review & Followup

    Rating: 5
    10G clarification??January 01, 2006
    Reviewer:? Brad ?from Dallas

    						
    								You say that PL/SQL and views in 10G would not be invalidated when the synonym 
    was redirected.  Would the view pick up the new table? 
    						


    Followup:
    														
    																Yes, the view would "pick up the new table"
    
    We will flip flop from T1 to T2 below:
    
    
    ops$tkyte@ORA10GR2> create table t1 ( x int );
    Table created.
    
    ops$tkyte@ORA10GR2> insert into t1 values ( 1 );
    1 row created.
    
    ops$tkyte@ORA10GR2> create or replace synonym t for t1;
    Synonym created.
    
    ops$tkyte@ORA10GR2> create or replace procedure p
      2  as
      3  begin
      4          for c in ( select * from t )
      5          loop
      6                  dbms_output.put_line( c.x );
      7          end loop;
      8  end;
      9  /
    Procedure created.
    
    ops$tkyte@ORA10GR2> create or replace view v as select * from t;
    View created.
    
    ops$tkyte@ORA10GR2>
    ops$tkyte@ORA10GR2> exec p
    1
    
    PL/SQL procedure successfully completed.
    
    ops$tkyte@ORA10GR2> select * from v;
    
             X
    ----------
             1
    
    ops$tkyte@ORA10GR2> select object_name, status from user_objects where 
    object_name in ( 'P', 'V' );
    
    OBJECT_NAME                    STATUS
    ------------------------------ -------
    P                              VALID
    V                              VALID
    
    ops$tkyte@ORA10GR2>
    ops$tkyte@ORA10GR2> create table t2 ( x int );
    
    Table created.
    
    ops$tkyte@ORA10GR2> insert into t2 values ( 2 );
    1 row created.
    
    ops$tkyte@ORA10GR2> create or replace synonym t for t2;
    Synonym created.
    
    ops$tkyte@ORA10GR2> select object_name, status from user_objects where 
    object_name in ( 'P', 'V' );
    
    OBJECT_NAME                    STATUS
    ------------------------------ -------
    P                              VALID?   --9i為INVALID?
    V                              VALID?   --9i為INVALID?
    
    ops$tkyte@ORA10GR2> exec p
    2
    
    PL/SQL procedure successfully completed.
    
    ops$tkyte@ORA10GR2> select * from v;
    
             X
    ----------
             2
    
    														




    -The End-

    posted on 2009-03-24 20:38 decode360-3 閱讀(316) 評論(0)  編輯  收藏 所屬分類: Toy
    主站蜘蛛池模板: 永久免费在线观看视频| 在线毛片片免费观看| 黄页免费的网站勿入免费直接进入| 国产亚洲成AV人片在线观黄桃| xvideos永久免费入口| 久久久久亚洲AV成人网人人软件| 一级毛片a免费播放王色| 国产亚洲精aa成人网站| 中文字幕免费在线看线人动作大片| 区久久AAA片69亚洲| 免费一区二区无码东京热| 亚洲av色福利天堂| 亚洲黄色片免费看| 中文字幕亚洲码在线| 四虎永久在线精品视频免费观看| 黄色免费网址在线观看| 亚洲人成伊人成综合网久久久| 国色精品va在线观看免费视频| 亚洲天堂男人天堂| 麻豆一区二区免费播放网站| 亚洲精品无码久久久久APP| 全部免费国产潢色一级| 国产精品hd免费观看| 亚洲AV成人无码久久精品老人| 久热中文字幕在线精品免费| 亚洲欧洲无码一区二区三区| 一级毛片直播亚洲| 精品国产污污免费网站| 亚洲偷偷自拍高清| 亚洲色欲久久久久综合网| 99久久精品免费视频| www亚洲精品久久久乳| 亚洲热妇无码AV在线播放| 久草视频免费在线观看| 在线观看亚洲网站| 亚洲三级电影网站| 四虎影视www四虎免费| 3344在线看片免费| 亚洲爆乳AAA无码专区| 亚洲AV无码精品无码麻豆| 四虎成人精品一区二区免费网站|