问题解决——出现符号 "("在需要下列之一时

今天在创建存储过程的时候,遇到了一个问题,如下:

PROCEDURE QIUYUE.PRO_INSERT_DYNA_TABLE 编译错误
错误:PLS-00103: 出现符号 "("在需要下列之一时:
        := . ) , @ % default
          character
       符号 ":=" 被替换为 "(" 后继续。
行:3
文本:id in number(3)

下面是我的存储过程:

create or replace procedure pro_insert_dyna_table
(
  id in number(3), 
  name in varchar2
) 
is 
str_sql varchar2(500);
begin
  str_sql :='insert into pro_create_dyna_table values(:1,:2)';
  execute immediate str_sql using id,name;
end pro_insert_dyna_table;

 

说是“(”的问题,但是,我仔细瞅了瞅,还是好好的。突然想到上午执行PL程序块时遇到了这样的问题:

declare
sum number;
begin
execute immediate 'select count(*) from stu' into sum; --注:into字句不可以放到引号中
dbms_output.put_line(sum);  --错误光标定位处
end;

 

ORA-06550: 第 5 行, 第 25 列:
PLS-00103: 出现符号 ")"在需要下列之一时:
 (


还是括号的问题,上午弄了好久,因为感觉简简单单的一句话,没有因为“)”而出错啊。后来不经意间,突然意识到了,sum是关键字。so……
那下午的情况是不是也是这样呢?
为了避免这种情况,我把id,name都换成了id1,name1,但是结果还是这样,晕!
还是因为突然的想法吧,我意识到了在创建存储过程的时候,对于参数的数据类型,不可以指定精确的类型,例如number的使用,在存储过程中不可以使用number(2)。

总结:

1、在定义变量名字的时候,一定要注意变量名字不可以是关键字
2、创建存储过程的时候,参数的数据类型不可以指定精确数据类型。例如,只能使用number、varchar2,而不可以使用varchar2(4)

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值