シノニムの作成にOracle SQL Developer 2.1を使用しています。
CREATE OR REPLACE SYNONYM "ETKS_PR_RW"."SQ_CLDOS_ATCHMNT_ID"
FOR "CLDOS_ONLINE_DBA"."SQ_CLDOS_ATCHMNT_ID";
このシノニムが既に存在する場合、そのシノニムを作成しないようにするにはどうすれば確認できますか。
replace
キーワードを使用しているため、同義語が最初に存在するかどうかを確認する必要はありません。以前の名前で存在した同義語はすべて上書きします。
replace
を使用する場合に注意する唯一の理由は、同じ名前の別の同義語がある可能性がある場合です。データベースが適切に編成されている場合、これは起こりません。すべてのオブジェクトが何であり、シノニムがどこを指しているのかを常に把握する必要があります。
ただし、必要な場合はいくつかのオプションがあります。
replace
を削除します。同義語が既に存在し、上書きされない場合、ステートメントはエラーをスローします。複数のスキーマを使用しているため、データディクショナリを照会します all_synonyms
が最善策のようです。
select *
from all_synonyms
where owner = 'ETKS_PR_RW'
and synonym_name = 'SQ_CLDOS_ATCHMNT_ID';
これらを単一のブロックに結合する場合は、次のようなことができます。
declare
l_exists number;
begin
-- check whether the synonym exists
select 1
into l_exists
from all_synonyms
where owner = 'ETKS_PR_RW'
and synonym_name = 'SQ_CLDOS_ATCHMNT_ID';
-- an error gets raise if it doesn-t.
exception when no_data_found then
-- DDL has to be done inside execute immediate in a block.
execute immediate 'CREATE OR REPLACE SYNONYM ETKS_PR_RW.SQ_CLDOS_ATCHMNT_ID
FOR CLDOS_ONLINE_DBA.SQ_CLDOS_ATCHMNT_ID';
end;
/
オブジェクト名を引用符で囲まないしないでください。オラクルはオブジェクトをケースに入れることができますが、面倒な価値はほとんどありません。すべてのオブジェクトは自動的に大文字になりますので、"
。
OR REPLACEキーワードを削除すると、存在することを促すメッセージが表示されます
または、これらのテーブルを使用してpl/sqlコードを作成できます
desc dba_synonyms
desc user_synonyms
それをより柔軟でカスタマイズするために
Oracle PL/SQLを想定
DECLARE
src_schema VARCHAR2(256) := 'EMPIK_DYNAMO_01';
target_schema VARCHAR2(256) := 'EMPIK_PORTAL_BETA_1';
CURSOR src_objects IS
SELECT table_name AS object_name
FROM all_all_tables
WHERE owner = src_schema
UNION
SELECT sequence_name AS object_name
FROM all_sequences
WHERE sequence_owner = src_schema;
BEGIN
FOR next_row IN src_objects LOOP
BEGIN
EXECUTE IMMEDIATE 'CREATE or REPLACE SYNONYM '|| target_schema|| '.'
||
next_row.object_name|| ' for '|| src_schema|| '.'||
next_row.object_name;
EXCEPTION
WHEN OTHERS THEN
dbms_output.Put_line('ERROR WHILE CREATING SYNONYM FOR: '
|| next_row.object_name);
dbms_output.Put_line(SQLERRM);
END;
END LOOP;
END;
/
ここであなたの問題のカスタマイズ
BEGIN
EXECUTE IMMEDIATE 'CREATE or REPLACE SYNONYM ETKS_PR_RW.SQ_CLDOS_ATCHMNT_ID FOR CLDOS_ONLINE_DBA.SQ_CLDOS_ATCHMNT_ID';
EXCEPTION
WHEN OTHERS THEN
dbms_output.Put_line ('ERROR WHILE CREATING SYNONYM FOR: SQ_CLDOS_ATCHMNT_ID');
dbms_output.Put_line (SQLERRM);
END;