<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 :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      397 隨筆 :: 33 文章 :: 29 評論 :: 0 Trackbacks
    同義詞切換對Objects的狀態影響
    ?
    ??? 改變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
    
    														
    posted on 2009-03-24 20:38 decode360 閱讀(399) 評論(0)  編輯  收藏 所屬分類: 07.Oracle
    主站蜘蛛池模板: 好大好硬好爽免费视频| 亚洲视频免费在线看| 欧美好看的免费电影在线观看| 猫咪www免费人成网站| 亚洲黄色在线观看| 国产亚洲一区区二区在线| 免费可以在线看A∨网站| 免费在线观看一级片| 免费国产va在线观看| 亚洲国产精品无码久久98 | 爱爱帝国亚洲一区二区三区| 久久精品国产亚洲av水果派| 亚洲中文字幕无码专区| 又黄又大又爽免费视频| 最新免费jlzzjlzz在线播放| 69精品免费视频| 免费91最新地址永久入口 | 亚洲国产成人五月综合网| 成人免费网站在线观看| 1000部拍拍拍18勿入免费凤凰福利| 大地资源中文在线观看免费版 | 亚洲国产成人久久精品99 | 黄色一级视频免费观看| 亚洲AV无码一区二区三区电影| 亚洲国产亚洲片在线观看播放 | 四虎成人精品永久免费AV| xxxxxx日本处大片免费看| 西西人体大胆免费视频| 亚洲AV成人片无码网站| 亚洲av日韩专区在线观看| 日韩亚洲国产高清免费视频| 亚洲AV综合色区无码二区爱AV| 亚洲最大黄色网站| 亚洲午夜在线一区| 国产99在线|亚洲| 亚洲精品自偷自拍无码| 亚洲AV第一成肉网| 极品美女一级毛片免费| 成人av片无码免费天天看| 人妻免费一区二区三区最新| 久久精品乱子伦免费|