Difference between revisions of "Dynamic SQL"
From dbawiki
(→Nice example from a question on AskTom) |
|||
| (3 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
* [[http://docs.oracle.com/cd/B28359_01/appdev.111/b28370/dynamic.htm Using Dynamic SQL]] | * [[http://docs.oracle.com/cd/B28359_01/appdev.111/b28370/dynamic.htm Using Dynamic SQL]] | ||
* [[http://asktom.oracle.com/pls/asktom/f?p=100:11:0::NO::P11_QUESTION_ID:227413938857 asktom discussion]] | * [[http://asktom.oracle.com/pls/asktom/f?p=100:11:0::NO::P11_QUESTION_ID:227413938857 asktom discussion]] | ||
| + | ===Nice example from a question on AskTom using dynamic sql passing an SQL statement as a parameter=== | ||
| + | Pretty print format a row from a table<br /> | ||
| + | * Ref: [https://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:9536889800346305468 - asktom.oracle.com] | ||
| + | <pre> | ||
| + | set serverout on size 999999 | ||
| + | set verify off | ||
| + | declare | ||
| + | p_query varchar2(32767) := q'{&1}'; | ||
| + | |||
| + | l_theCursor integer default dbms_sql.open_cursor; | ||
| + | l_columnValue varchar2(4000); | ||
| + | l_status integer; | ||
| + | l_descTbl dbms_sql.desc_tab; | ||
| + | l_colCnt number; | ||
| + | n number := 0; | ||
| + | procedure p(msg varchar2) is | ||
| + | l varchar2(4000) := msg; | ||
| + | begin | ||
| + | while length(l) > 0 loop | ||
| + | dbms_output.put_line(substr(l,1,80)); | ||
| + | l := substr(l,81); | ||
| + | end loop; | ||
| + | end; | ||
| + | begin | ||
| + | execute immediate | ||
| + | 'alter session set nls_date_format=''dd-mon-yyyy hh24:mi:ss'' '; | ||
| + | |||
| + | dbms_sql.parse( l_theCursor, p_query, dbms_sql.native ); | ||
| + | dbms_sql.describe_columns( l_theCursor, l_colCnt, l_descTbl ); | ||
| + | |||
| + | for i in 1 .. l_colCnt loop | ||
| + | dbms_sql.define_column(l_theCursor, i, l_columnValue, 4000); | ||
| + | end loop; | ||
| + | |||
| + | l_status := dbms_sql.execute(l_theCursor); | ||
| + | |||
| + | while ( dbms_sql.fetch_rows(l_theCursor) > 0 ) loop | ||
| + | for i in 1 .. l_colCnt loop | ||
| + | dbms_sql.column_value( l_theCursor, i, l_columnValue ); | ||
| + | p( rpad( l_descTbl(i).col_name, 30 ) | ||
| + | || ': ' || | ||
| + | l_columnValue ); | ||
| + | end loop; | ||
| + | dbms_output.put_line( '-----------------' ); | ||
| + | n := n + 1; | ||
| + | end loop; | ||
| + | if n = 0 then | ||
| + | dbms_output.put_line( chr(10)||'No data found '||chr(10) ); | ||
| + | end if; | ||
| + | end; | ||
| + | / | ||
| + | |||
| + | set verify on | ||
| + | |||
| + | SQL> @pt "select * from scott.emp where rownum = 1" | ||
| + | EMPNO : 7369 | ||
| + | ENAME : SMITH | ||
| + | JOB : CLERK | ||
| + | MGR : 7902 | ||
| + | HIREDATE : 17-dec-1980 00:00:00 | ||
| + | SAL : 800 | ||
| + | COMM : | ||
| + | DEPTNO : 20 | ||
| + | ----------------- | ||
| + | |||
| + | PL/SQL procedure successfully completed. | ||
| + | |||
| + | SQL> @pt "select * from scott.dept where rownum = 1" | ||
| + | DEPTNO : 10 | ||
| + | DNAME : ACCOUNTING | ||
| + | LOC : NEW YORK | ||
| + | ----------------- | ||
| + | |||
| + | PL/SQL procedure successfully completed. | ||
| + | |||
| + | SQL> | ||
| + | </pre> | ||
| + | |||
| + | ===Drop database links by creating a procedure as the user then running the procedure=== | ||
| + | <pre> | ||
| + | printf "\n\n%s\n" "*** Removing the database links from db_sizing ***" | ||
| + | cat<<EOSQL >"/tmp/results.deletedb.appli.${TO_SID}.sql" | ||
| + | grant create database link to db_sizing; | ||
| + | grant select on sys.dba_db_links to db_sizing; | ||
| + | set pages 0 newpa none lines 1000 feed off serveroutput on | ||
| + | create or replace procedure db_sizing.drop_db_link as | ||
| + | l_db_link varchar2(4000); | ||
| + | l_stmt varchar2(4000); | ||
| + | begin | ||
| + | dbms_output.enable(null); | ||
| + | select db_link | ||
| + | into l_db_link | ||
| + | from sys.dba_db_links | ||
| + | where owner = 'DB_SIZING' | ||
| + | and db_link like '%${TO_SID_UPPER}%'; | ||
| + | select 'drop database link '||l_db_link into l_stmt from dual; | ||
| + | dbms_output.put_line(l_stmt); | ||
| + | execute immediate l_stmt; | ||
| + | exception | ||
| + | when no_data_found then | ||
| + | dbms_output.put_line('No link matching %${TO_SID_UPPER}% found.'); | ||
| + | end drop_db_link; | ||
| + | / | ||
| + | exec db_sizing.drop_db_link; | ||
| + | revoke create database link from db_sizing; | ||
| + | drop procedure db_sizing.drop_db_link; | ||
| + | EOSQL | ||
| + | </pre> | ||
Latest revision as of 13:12, 4 September 2018
Nice example from a question on AskTom using dynamic sql passing an SQL statement as a parameter[edit]
Pretty print format a row from a table
- Ref: - asktom.oracle.com
set serverout on size 999999
set verify off
declare
p_query varchar2(32767) := q'{&1}';
l_theCursor integer default dbms_sql.open_cursor;
l_columnValue varchar2(4000);
l_status integer;
l_descTbl dbms_sql.desc_tab;
l_colCnt number;
n number := 0;
procedure p(msg varchar2) is
l varchar2(4000) := msg;
begin
while length(l) > 0 loop
dbms_output.put_line(substr(l,1,80));
l := substr(l,81);
end loop;
end;
begin
execute immediate
'alter session set nls_date_format=''dd-mon-yyyy hh24:mi:ss'' ';
dbms_sql.parse( l_theCursor, p_query, dbms_sql.native );
dbms_sql.describe_columns( l_theCursor, l_colCnt, l_descTbl );
for i in 1 .. l_colCnt loop
dbms_sql.define_column(l_theCursor, i, l_columnValue, 4000);
end loop;
l_status := dbms_sql.execute(l_theCursor);
while ( dbms_sql.fetch_rows(l_theCursor) > 0 ) loop
for i in 1 .. l_colCnt loop
dbms_sql.column_value( l_theCursor, i, l_columnValue );
p( rpad( l_descTbl(i).col_name, 30 )
|| ': ' ||
l_columnValue );
end loop;
dbms_output.put_line( '-----------------' );
n := n + 1;
end loop;
if n = 0 then
dbms_output.put_line( chr(10)||'No data found '||chr(10) );
end if;
end;
/
set verify on
SQL> @pt "select * from scott.emp where rownum = 1"
EMPNO : 7369
ENAME : SMITH
JOB : CLERK
MGR : 7902
HIREDATE : 17-dec-1980 00:00:00
SAL : 800
COMM :
DEPTNO : 20
-----------------
PL/SQL procedure successfully completed.
SQL> @pt "select * from scott.dept where rownum = 1"
DEPTNO : 10
DNAME : ACCOUNTING
LOC : NEW YORK
-----------------
PL/SQL procedure successfully completed.
SQL>
Drop database links by creating a procedure as the user then running the procedure[edit]
printf "\n\n%s\n" "*** Removing the database links from db_sizing ***"
cat<<EOSQL >"/tmp/results.deletedb.appli.${TO_SID}.sql"
grant create database link to db_sizing;
grant select on sys.dba_db_links to db_sizing;
set pages 0 newpa none lines 1000 feed off serveroutput on
create or replace procedure db_sizing.drop_db_link as
l_db_link varchar2(4000);
l_stmt varchar2(4000);
begin
dbms_output.enable(null);
select db_link
into l_db_link
from sys.dba_db_links
where owner = 'DB_SIZING'
and db_link like '%${TO_SID_UPPER}%';
select 'drop database link '||l_db_link into l_stmt from dual;
dbms_output.put_line(l_stmt);
execute immediate l_stmt;
exception
when no_data_found then
dbms_output.put_line('No link matching %${TO_SID_UPPER}% found.');
end drop_db_link;
/
exec db_sizing.drop_db_link;
revoke create database link from db_sizing;
drop procedure db_sizing.drop_db_link;
EOSQL