Oracle PL/SQL - Reusing Bind Variables in Dynamic SQL

Description

Reusing Bind Variables in Dynamic SQL

Demo

SQL>
SQL> drop table emp;

Table dropped.--   w ww.  j  a v  a  2s  .  c o m
SQL> create table emp(
  2    empno    number(4,0),
  3    ename    varchar2(10),
  4    job      varchar2(9),
  5    mgr      number(4,0),
  6    hiredate date,
  7    sal      number(7,2),
  8    comm     number(7,2),
  9    deptno   number(2,0)
 10  );

Table created.
SQL>
SQL> insert into emp values(7839, 'KING', 'PRESIDENT', null, to_date('17-11-1981','dd-mm-yyyy'), 5000, null, 10);
SQL> insert into emp values(7698, 'BLAKE', 'MANAGER', 7839,to_date('1-5-1981','dd-mm-yyyy'), 2850, null, 30);
SQL> declare
  2       v_nr NUMBER:=100;
  3       v_where_tx VARCHAR2(2000):='deptNo=20';
  4       v_sql_tx VARCHAR2(2000);
  5  begin
  6       v_sql_tx:='update emp ' ||
  7                 ' set sal=:1, comm=:1 ' ||
  8                 'where '||v_where_tx;
  9       execute immediate v_sql_tx using v_nr, v_nr;
 10  end;
 11  /

PL/SQL procedure successfully completed.
SQL>

Related Topic