oracle 变量绑定 ORA-00903错误:无效表名

今天在开发中,我下面的需求:我需要从不同的表中查找数据,但是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解析的时候,首先要知道操作的是那个表,再看用户有没有这个表的权限,可能还有其它的原因,所以,表名不能被绑定。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值