亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

講解物化視圖ORA-23313錯誤的解決方法

2024-07-21 02:42:26
字體:
來源:轉載
供稿:網友

問題:

物化視圖問題:

物化視圖復制的設置

主站點:db001.d-link

物化視圖站點:db002.d-link

主機名:dbmis

復制用戶:dev001

檢查初始化參數

SQL> connect sys/change_on_install@db001.d-link as sysdba ;

已連接。

SQL> show parameter global_names ;

NAME TYPE VALUE

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

global_names boolean TRUE

SQL> show parameter job;

NAME TYPE VALUE

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

job_queue_PRocesses integer 20

SQL> select * from global_name ;

GLOBAL_NAME

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

DB001.d-link

SQL>

SQL> connect sys/change_on_install@db002.d-link as sysdba ;

已連接。

SQL> show parameter global_names ;

NAME TYPE VALUE

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

global_names boolean TRUE

SQL> show parameter job;

NAME TYPE VALUE

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

job_queue_processes integer 10

SQL> select * from global_name ;

GLOBAL_NAME

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

DB002.d-link

SQL>

檢查全局數據庫名稱

SQL> connect dev001/whoami@db002.d-link ;

已連接。

SQL> select * from dev001.test001@db001 ;

A B

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

1 wui

2 zyun

SQL>

SQL> connect sys/change_on_install@db002.d-link as sysdba ;

已連接。

SQL> select owner,db_link from all_db_links ;

OWNER DB_LINK

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

SYS DB001.d-link

PUBLIC DB001.d-link

SQL> connect sys/change_on_install@db001.d-link as sysdba ;

已連接。

SQL> select owner,db_link from all_db_links ;

OWNER DB_LINK

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

SYS DB002.d-link

PUBLIC DB002.d-link

SQL>

建立主體站點

SQL> connect system/whoami@db001.d-link ;

已連接。

SQL>

--建立復制管理用戶repadmin 并授權

CREATE USER repadmin IDENTIFIED BY repadmin;

BEGIN

DBMS_REPCAT_ADMIN.GRANT_ADMIN_ANY_SCHEMA (username => 'repadmin');

END;

/

GRANT COMMENT ANY TABLE TO repadmin;

GRANT LOCK ANY TABLE TO repadmin;

GRANT SELECT ANY DICTIONARY TO repadmin;

--注冊傳播用戶并授權

BEGIN

DBMS_DEFER_SYS.REGISTER_PROPAGATOR (username => 'repadmin');

END;

/

--注冊接收用戶

BEGIN

DBMS_REPCAT_ADMIN.REGISTER_USER_REPGROUP (

username => 'repadmin',

privilege_type => 'receiver',

list_of_gnames => NULL);

END;

/

--建立物化視圖站點復制管理員的代理用戶

BEGIN

DBMS_REPCAT_ADMIN.REGISTER_USER_REPGROUP (

username => 'repadmin',

privilege_type => 'proxy_snapadmin',

list_of_gnames => NULL);

END;

/

GRANT CREATE session TO repadmin;

GRANT SELECT ANY TABLE TO repadmin;

--以復制管理員身份登陸到主站點

SQL> CONNECT repadmin/repadmin@db001.d-link ;

BEGIN

DBMS_DEFER_SYS.SCHEDULE_PURGE (

next_date => SYSDATE,

interval => 'SYSDATE + 1/24',

delay_seconds => 0);

END;

/

commit;

設置物化視圖站點

SQL> connect system/whoami@db002.d-link ;

--建立物化視圖管理員,并授權

CREATE USER mvadmin IDENTIFIED BY mvadmin;

BEGIN

DBMS_REPCAT_ADMIN.GRANT_ADMIN_ANY_SCHEMA (

username => 'mvadmin');

END;

/

GRANT COMMENT ANY TABLE TO mvadmin;

GRANT LOCK ANY TABLE TO mvadmin;

GRANT SELECT ANY DICTIONARY TO mvadmin;

--建立傳播者,并授權

BEGIN

DBMS_DEFER_SYS.REGISTER_PROPAGATOR (username => 'mvadmin');

END;

/

--建立刷新者,并授權,這里使用mvadmin 用戶刷新物化視圖

GRANT CREATE SESSION TO mvadmin;

GRANT ALTER ANY MATERIALIZED VIEW TO mvadmin;

--注冊接受者

BEGIN

DBMS_REPCAT_ADMIN.REGISTER_USER_REPGROUP (

username => 'mvadmin',

privilege_type => 'receiver',

list_of_gnames => NULL);

END;

/

--建立PUBLIC 數據庫鏈

CREATE PUBLIC DATABASE LINK db001 USING 'db001.d-link';

SQL> CONNECT mvadmin/mvadmin@db002.d-link;

已連接。

SQL>CREATE DATABASE LINK db001 CONNECT TO repadmin IDENTIFIED BY repadmin;

--建立到主站點上復制管理員的數據庫鏈

--以傳播者身份登陸物化視圖站點

BEGIN

DBMS_DEFER_SYS.SCHEDULE_PURGE (

next_date => SYSDATE,

interval => 'SYSDATE + 1/24',

delay_seconds => 0,

rollback_segment => '');

END;

/

--設置將修改推入到主站點的job

BEGIN

DBMS_DEFER_SYS.SCHEDULE_PUSH (

destination => 'db001.d-link',

interval => 'SYSDATE + 1/24',

next_date => SYSDATE,

stop_on_error => FALSE,

delay_seconds => 0,

parallelism => 0);

END;

/

commit;

建立主體組

--以復制管理員身份登陸復制站點

CONNECT repadmin/repadmin@db001.d-link ;

--建立名為rep_test 的復制組

BEGIN

DBMS_REPCAT.CREATE_MASTER_REPGROUP (

gname => 'reptest');

END;

/

--將復制對象增加到復制組中

BEGIN

DBMS_REPCAT.CREATE_MASTER_REPOBJECT (

gname => 'rep_test',

type => 'TABLE',

oname => 'test001',

sname => 'dev001',

use_existing_object => TRUE,

copy_rows => FALSE);

END;

/

--生成復制支持

BEGIN

DBMS_REPCAT.GENERATE_REPLICATION_SUPPORT (

sname => 'dev001',

oname => 'test001',

type => 'TABLE',

min_communication => TRUE);

END;

/

--開始復制

BEGIN

DBMS_REPCAT.RESUME_MASTER_ACTIVITY (

gname => 'reptest');

END;

/

commit;

建立物化視圖

CONNECT dev001/whoami@db001.d-link ;

--建立物化視圖日志表,FAST 刷新方式必須要求建立物化視圖日志

CREATE MATERIALIZED VIEW LOG ON dev001.test001;

--建立復制用戶到主站點代理刷新者的數據庫鏈

CONNECT dev001/whoami@db002.d-link;

CREATE DATABASE LINK db001 CONNECT TO repadmin IDENTIFIED BY repadmin;

--建立物化視圖組

CONNECT mvadmin/mvadmin@db002.d-link ;

--物化視圖組必須和復制站點上的復制組名稱相同

BEGIN

DBMS_REPCAT.CREATE_MVIEW_REPGROUP (

gname => 'reptest',

master => 'db001.d-link',

propagation_mode => 'ASYNCHRONOUS');

END;

/

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

錯誤提示:

SQL> begin

2 dbms_repcat.create_mview_repgroup(

3 gname=>'reptest',

4 master=>'db001.d-link',

5 propagation_mode => 'ASYNCHRONOUS');

6 end;

7 /

begin

*

ERROR 位于第 1 行:

ORA-23313: 在 PUBLIC 沒有控制對象組 "REPTEST"."db001.d-link"

ORA-06512: 在"SYS.DBMS_SYS_ERROR", line 105

ORA-06512: 在"SYS.DBMS_REPCAT_SNA_UTL", line 1690

ORA-06512: 在"SYS.DBMS_REPCAT_SNA", line 64

ORA-06512: 在"SYS.DBMS_REPCAT", line 1262

ORA-06512: 在line 2

SQL>

查找資料后得到的結論:說是因為目前主站屬于靜默模式,解決過程如下:

BEGIN

DBMS_REPCAT.RESUME_MASTER_ACTIVITY (

gname => 'reptest');

END;

/

但依然無效,同樣樣報錯,上午這樣執行一下后,建立物化視圖組雖然通過了,但意外的是,

現在把所有都刪除了重新建立,竟然報錯誤了。

SQL> connect repadmin/repadmin@db001.d-link ;

已連接。

SQL> select gname, master, status from dba_repgroup;

GNAME M STATUS

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

REPTEST Y NORMAL

按照其他方法:

SQL> execute dbms_repcat.suspend_master_activity (gname => 'reptest');

PL/SQL 過程已成功完成。

SQL> connect mviewadmin/mviewadmin@db002.d-link ;

已連接。

SQL> begin

2 dbms_repcat.create_mview_repgroup(

3 gname=>'reptest',

4 master=>'db001.d-link',

5 propagation_mode=>'ASYNCHRONOUS');

6 end;

7 /

begin

*

ERROR 位于第 1 行:

ORA-23313: 在 PUBLIC 沒有控制對象組 "REPTEST"."db001.d-link"

ORA-06512: 在"SYS.DBMS_SYS_ERROR", line 105

ORA-06512: 在"SYS.DBMS_REPCAT_SNA_UTL", line 1690

ORA-06512: 在"SYS.DBMS_REPCAT_SNA", line 64

ORA-06512: 在"SYS.DBMS_REPCAT", line 1262

ORA-06512: 在line 2

SQL>

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

--創建刷新組

BEGIN

DBMS_REFRESH.MAKE (

name => 'mvadmin.rep_refresh',

list => '',

next_date => SYSDATE,

interval => 'SYSDATE + 1/24',

implicit_destroy => FALSE,

rollback_seg => '',

push_deferred_rpc => TRUE,

refresh_after_errors => FALSE);

END;

/

SQL> connect mviewadmin/mviewadmin@db002.d-link ;

已連接。

SQL> select *from dev001.test001@db001 ;

A B

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

1 wui

2 zyun

SQL>

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

--創建物化視圖

SQL> CREATE MATERIALIZED VIEW dev001.test001

2 REFRESH FAST WITH PRIMARY KEY FOR UPDATE

3 AS SELECT * FROM dev001.test001@db001 ;

AS SELECT * FROM dev001.test001@db001

*

ERROR 位于第 3 行:

ORA-12028: 主體站點 @DB001.d-link 不支持實體化視圖類型

SQL>

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

(兩處用長虛線的位置是問題所在)。

解決方法:(參考)

在進行復制組創建的過程中出現如下錯誤:

SQL> begin

2 dbms_repcat.create_mview_repgroup(

3 gname=>'reptest',

4 master=>'db001.d-link',

5 propagation_mode => 'ASYNCHRONOUS');

6 end;

7 /

begin

*

ERROR 位于第 1 行:

ORA-23313: 在 PUBLIC 沒有控制對象組 "REPTEST"."db001.d-link"

ORA-06512: 在"SYS.DBMS_SYS_ERROR", line 105

ORA-06512: 在"SYS.DBMS_REPCAT_SNA_UTL", line 1690

ORA-06512: 在"SYS.DBMS_REPCAT_SNA", line 64

ORA-06512: 在"SYS.DBMS_REPCAT", line 1262

ORA-06512: 在line 2

經多次檢查后發現問題出現在db link上,在測試中發現的問題:

SQL> connect system/pass@db002 ;

已連接。

SQL> select owner,db_link from dba_db_links ;

OWNER DB_LINK

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

PUBLIC DB001.Q-LINK

MVADMIN DB001.Q-LINK

DEV001 DB001.Q-LINK

SQL> connect system/pass@db001 ;

已連接。

SQL> select owner,db_link from dba_db_links ;

OWNER DB_LINK

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

PUBLIC DB002.Q-LINK

REPADMIN DB002.Q-LINK

SQL> connect mvadmin/pass@db002

已連接。

SQL> select * from dev001.test001@db001 ;

A B

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

1 wanghui

2 zhangyun

SQL> select * from dev001.test001@db001.q-link ;

select * from dev001.test001@db001.q-link

*

ERROR 位于第 1 行:

ORA-00933: SQL 命令未正確結束

SQL>

當引用類似"db001.q-link"的db link時,Oracle出現了錯誤,此時應注意"-"這個特殊字符,因為Oracle在db link 中無法正確的識別。

然后加上雙引號(""),如下:

select * from dev001.test001@"db001.q-link" ;

此時結果正?!,F在就可以確認是域名出現問題了。

然后通過使用類似命令更改了域名以后,即可恢復正常:

alter database rename global_name to DB002.QLINK;

問題的詳細描述,Note:274162.1

The above problem is known to arise due to the presence of the '-' character in the domain name. Upon renaming the domain to a name that doesn't contain this character, the above problem disappears. Oracle的說法:

The cause of this occurance is not clear. 報告中的影響范圍為:

Oracle Net Services - Version: 8.1.7.4 to 8.1.7.4

Solaris Operating System (SPARC 32-bit)

注釋:Oracle 9i中此問題也同樣存在,此示例的數據庫版本如下:

SQL> select * from v$version ;

BANNER

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

Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production

PL/SQL Release 9.2.0.1.0 - Production

CORE 9.2.0.1.0 Production

TNS for 32-bit Windows: Version 9.2.0.1.0 - Production

NLSRTL Version 9.2.0.1.0 - Production

SQL>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久精品美女高潮| 国产精品久久久久久久天堂| 日韩在线视频观看正片免费网站| 亚洲小视频在线| 中文精品99久久国产香蕉| 麻豆国产va免费精品高清在线| 在线观看视频亚洲| 久久91精品国产91久久久| 成人久久18免费网站图片| 高清视频欧美一级| 欧美日韩综合视频网址| 国产精品久久久久一区二区| 欧美激情一区二区三区在线视频观看| 亚洲xxx自由成熟| 国产一区二区三区在线观看网站| 青青青国产精品一区二区| 色无极影院亚洲| 黑人巨大精品欧美一区免费视频| 两个人的视频www国产精品| 国产精品99久久99久久久二8| 成人国内精品久久久久一区| 亚洲日本中文字幕免费在线不卡| 日韩精品久久久久久久玫瑰园| 日韩精品视频在线免费观看| 欧美激情一级精品国产| 2019精品视频| 久久久亚洲影院| www.日本久久久久com.| 久久久免费高清电视剧观看| 欧美性猛交xxxx免费看久久久| 亚洲国产精品成人va在线观看| 久久精品国产成人| 91久久精品在线| 91国产中文字幕| 中文字幕在线精品| 亚洲电影免费观看高清完整版在线观看| 91久久久久久久| 亚洲日本欧美日韩高观看| 91沈先生在线观看| 国产欧美日韩精品丝袜高跟鞋| 91精品国产91久久久久久不卡| 日韩电影免费在线观看| 在线看国产精品| 亚洲韩国欧洲国产日产av| 日韩少妇与小伙激情| 国产美女精品视频免费观看| 中文字幕av一区二区| 亚洲人成亚洲人成在线观看| 国产精品视频1区| 国产精品一区二区久久精品| 夜夜嗨av一区二区三区免费区| 欧美成人免费全部观看天天性色| 亚洲影院高清在线| 欧美激情极品视频| 亚洲国内高清视频| 成人乱色短篇合集| 性日韩欧美在线视频| 欧美资源在线观看| 久久在线视频在线| 国产精品久久久久久五月尺| 欧美在线观看视频| 中文字幕亚洲欧美日韩高清| 亚洲一区亚洲二区亚洲三区| 欧美高清性猛交| 欧美一区二区视频97| 国产最新精品视频| 欧美亚洲成人精品| 久久久国产一区二区| 国产成人精品免费视频| 国产91色在线| 国产91精品久久久久久| 国产欧美日韩精品在线观看| 亚洲激情成人网| xxx一区二区| 自拍偷拍亚洲精品| 久久这里只有精品视频首页| 欧美精品在线免费观看| 日韩欧美国产成人| 久久久成人的性感天堂| 欧美激情欧美狂野欧美精品| 亚洲国产欧美在线成人app| 亚洲欧美视频在线| 国产一区二区三区在线播放免费观看| 国产91在线高潮白浆在线观看| 欧美性20hd另类| 亚洲欧洲在线看| 欧美成人午夜激情视频| 国产精品免费视频久久久| 日韩中文综合网| 欧美在线不卡区| 久久久91精品国产| 国产成人精品日本亚洲专区61| 欧美日韩亚洲视频| 激情久久av一区av二区av三区| 综合国产在线视频| 中文字幕免费精品一区| 国产热re99久久6国产精品| 久久综合免费视频影院| 国产综合在线视频| 久久久久久国产精品| 97碰在线观看| 91免费看片在线| 成人黄在线观看| 庆余年2免费日韩剧观看大牛| 大胆欧美人体视频| 亚洲四色影视在线观看| 亚洲人a成www在线影院| 97精品伊人久久久大香线蕉| 另类天堂视频在线观看| 亚洲最大福利网| 国产在线观看91精品一区| 日韩欧美国产中文字幕| 亚洲最大av在线| 久久综合色影院| 久久视频精品在线| 91av在线看| 亚洲国产精品专区久久| 欧美中文字幕视频在线观看| 久久777国产线看观看精品| 欧美激情中文字幕乱码免费| 久久久久久18| 欧洲成人性视频| 国产精品日韩在线播放| 久久中文字幕一区| 精品日韩视频在线观看| 91精品国产高清| 国产日韩av在线播放| 最新国产成人av网站网址麻豆| 美女扒开尿口让男人操亚洲视频网站| 欧美日韩一区二区三区在线免费观看| 精品亚洲一区二区三区四区五区| 欧美日韩免费在线| 成人网在线免费看| 日韩最新av在线| 国产精品久久久久久搜索| 一本色道久久综合狠狠躁篇怎么玩| 日韩欧美中文在线| 国产区精品在线观看| 亚洲深夜福利网站| 911国产网站尤物在线观看| 欧美激情亚洲另类| 日本伊人精品一区二区三区介绍| 麻豆一区二区在线观看| 欧美国产精品人人做人人爱| 国产精品视频在线播放| 亚洲а∨天堂久久精品9966| 亚洲性69xxxbbb| 精品成人国产在线观看男人呻吟| 高清在线视频日韩欧美| 亚洲男人天堂久| 欧美资源在线观看| 欧美天天综合色影久久精品| 日韩大胆人体377p| 国产日韩中文字幕| 亲爱的老师9免费观看全集电视剧| 热草久综合在线| 91久久久久久久| 成人精品久久av网站| 性欧美视频videos6一9| 国产精品一区二区三区久久| 欧美日韩亚洲高清| 国产成人精品亚洲精品| 国产精品偷伦一区二区| 精品久久香蕉国产线看观看gif|