-
Notifications
You must be signed in to change notification settings - Fork 129
/
Copy pathdblink_details.sql
39 lines (36 loc) · 1.33 KB
/
dblink_details.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/*
-- For a scheduler job one can define the owner. The job will run below that schema
-- A scheduler job can run in the current session. This enables us to capture the dbms_output
*/
BEGIN
FOR f IN (SELECT *
FROM dba_db_links
WHERE owner not in ('PUBLIC')
)
LOOP
DBMS_SCHEDULER.create_job (
job_name => f.owner || '.DBLINK',
job_type => 'PLSQL_BLOCK',
job_action => 'DECLARE '
|| ' X CHAR; '
|| 'BEGIN '
|| ' SELECT dummy into x from dual@'
|| f.db_link
|| ' ;'
|| ' DBMS_OUTPUT.put_line('''
|| f.owner
|| ' '
|| f.db_link
|| ' VALID'');'
|| 'END ; '
);
BEGIN
DBMS_SCHEDULER.run_job (f.owner || '.DBLINK ', TRUE);
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.put_line (f.owner || ' ' || f.db_link || ' INVALID (ORA' || SQLCODE || ')');
END;
DBMS_SCHEDULER.drop_job (f.owner || ' . DBLINK ');
END LOOP;
END;
/