今天在开发中,我下面的需求:我需要从不同的表中查找数据,但是SQL相对固定:
select count(*) cnt from table_a where code =codevalue;
在上面的SQL语句中,只有table_a 和codevalue会发生变化,因此,我们变量绑定的方法来做:
如下所示:
select count(*) cnt from :1 where code = :2
整个调用如下:
create or replace procedure test(sCode IN varchar2, icount out number) is
begin
execute immediate 'select count(*) cnt from :1 where code = :2'
into icount
using 'gd_side', sCode;
end test;
但在执行的时候报 ORA-00903错误:无效的表名。
改成下面的方法后,一切正常:
create or replace procedure test(sCode IN varchar2, icount out number) is
begin
execute immediate 'select count(*) cnt from '||table_name||' where code = :1'
into icount
using sCode;
end test;
和前面的区别是表名不再用绑定的方法,而是用 || 方法。
最后,查找资源,发现表名不能被绑定,因为在SQL解析的时候,首先要知道操作的是那个表,再看用户有没有这个表的权限,可能还有其它的原因,所以,表名不能被绑定。