我们可以将动态查询的结果存储到变量中并在if块中使用吗?

时间:2012-05-24 02:47:32

标签: sql plsql plsqldeveloper

Declare
v_count number 
v_sql varchar2(1000);

begin 

v_count :='select count(*) from table_name';

 Execute Immediate v_count;

if(v_count <>0) then 

v_sql :='delete table_name where x=X' ;

Execute Immediate v_sql ;

End if ;

end;

任务是我们必须使用动态查询来查表。上述查询工作会不会? 它给了我一些类型转换错误..

或者是否存在存储Dynamic sql查询结果的替代方法

1 个答案:

答案 0 :(得分:3)

试试这个:

Declare
v_statement varchar2(32767);
v_count number; 
v_sql varchar2(1000);

begin 

 v_statement :='select count(*) from table_name';

 Execute Immediate l_statement into v_count;

  if v_count >0 then 
   ...
  end if ;

end;