oracle修改账号密码问题解决——出现符号"("在需要下列之一时)

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

 

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

  www.2cto.com  

PROCEDURE QIUYUE.PRO_INSERT_DYNA_TABLE 编译错误

错误:PLS-00103: 出现符号 "("在需要下列之一时:

        := . ) , @ % default

          character

       符号 ":=" 被替换为 "(" 后继续。

行:3

文本:id in number(3)

 

下面是我的存储过程:

[sql] 

create or replace procedure pro_insert_dyna_table  

(    www.2cto.com  

  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程序块时遇到了这样的问题:

[sql] 

declare  

sum number;  

begin  

execute immediate 'select count(*) from stu' into sum; –注:into字句不可以放到引号中  

dbms_output.put_line(sum);  –错误光标定位处  

end;  

 

ORA-06550: 第 5 行, 第 25 列:&oracle账号nbsp;

PLS-00103: 出现符号 ")"在需要下列之一时:

 (  www.2cto.com  

 

还是括号的问题,上午弄了好久,因为感觉简简单单的一句话,没有因为“)”而出错啊。后来不经意间,突然意识到了,sum是关键字。so……

那下午的情况是不是也是这样呢?

为了避免这种情况,我把id,name都换成了id1,name1,但是结果还是这样,晕!

还是因为突然的想法吧,我意识到了在创建存储过程的时候,对于参数的数据类型,不可以指定精确的类型,例如number的使用,在存储过程中不可以使用number(2)。

 

总结:

1、在定义变量名字的时候,一定要注意变量名字不可以是关键字

2、创建存储过程的时候,参数的数据类型不可以指定精确数据类型。例如,只能使用number、varchar2,而不可以使用varchar2(4)

 

 

作者 yang15225094594

此条目发表在oracle metalink账号分类目录,贴了标签。将固定链接加入收藏夹。