Oracle 如何修复';遇到符号“=&引用;当预期出现以下情况之一时:';plsql中的错误
我正在尝试使用PL/SQL过程从表中获取结果 这就是程序Oracle 如何修复';遇到符号“=&引用;当预期出现以下情况之一时:';plsql中的错误,oracle,plsql,plsqldeveloper,Oracle,Plsql,Plsqldeveloper,我正在尝试使用PL/SQL过程从表中获取结果 这就是程序 CREATE OR REPLACE PROCEDURE getEmpById( e_id IN employee.empid%TYPE, emp_name OUT employee.empname%TYPE, emp_desig OUT employee.designation%TYPE) IS BEGIN SELECT empname,designation INTO emp_name,
CREATE OR REPLACE PROCEDURE getEmpById(
e_id IN employee.empid%TYPE,
emp_name OUT employee.empname%TYPE,
emp_desig OUT employee.designation%TYPE)
IS
BEGIN
SELECT empname,designation INTO emp_name, emp_desig FROM employee WHERE empid = e_id;
END;
/
这是呼叫区
DECLARE
e_id:=&e_id;
emp_name employee.empname%TYPE;
emp_desig employee.designation%TYPE;
BEGIN
getEmpById(e_id,emp_name,emp_desig);
DBMS_OUTPUT.PUT_LINE('Name : ' || emp_name);
DBMS_OUTPUT.PUT_LINE('Designation : ' || emp_desig);
END;
/
这就是我得到的错误
Enter value for e_id: 'AIT005'
old 2: e_id:=&e_id;
new 2: e_id:='AIT005';
e_id:='AIT005';
*
ERROR at line 2:
ORA-06550: line 2, column 8:
PLS-00103: Encountered the symbol "=" when expecting one of the following:
constant exception <an identifier>
<a double-quoted delimited-identifier> table LONG_ double ref
char time timestamp interval date binary national character
nchar
The symbol "<an identifier>" was substituted for "=" to continue.
输入e_id的值:“AIT005”
旧2:e_id:=&e_id;
新2:e_id:=“AIT005”;
e_id:='AIT005';
*
第2行错误:
ORA-06550:第2行第8列:
PLS-00103:在预期以下情况时遇到符号“=”:
恒定异常
表长双参考
字符时间戳间隔日期二进制国家字符
固定长度
符号“”已替换为“=”以继续。
您缺少E_ID的数据类型(在声明部分)
下面是一个例子:
SQL> create table employee (empid number, empname varchar2(10), designation varchar2(10));
Table created.
SQL> insert into employee values (1, 'Little', 'Foot');
1 row created.
SQL> create or replace procedure getempbyid(
2 e_id in employee.empid%type,
3 emp_name out employee.empname%type,
4 emp_desig out employee.designation%type)
5 is
6 begin
7 select empname,designation into emp_name, emp_desig from employee where empid = e_id;
8 end;
9 /
Procedure created.
测试:
SQL> set serveroutput on
SQL> set ver off
SQL> declare
2 e_id employee.empid%type := &e_id; --> you're missing E_ID datatype here
3 emp_name employee.empname%type;
4 emp_desig employee.designation%type;
5 begin
6 getempbyid(e_id,emp_name,emp_desig);
7 dbms_output.put_line('Name : ' || emp_name);
8 dbms_output.put_line('Designation : ' || emp_desig);
9 end;
10 /
Enter value for e_id: 1
Name : Little
Designation : Foot
PL/SQL procedure successfully completed.
SQL>
你能指出你的e\u id
声明与emp\u name
和emp\u desig
声明之间的区别吗?@apc e\u id是过程中的变量名,但empid是表中的列名,这是不会引起任何问题的区别。。。但是,尽管我使用相同的名称进行了检查,但也出现了相同的错误。我的意思是,emp_name
和emp_desig
的声明包含了数据类型,而您的e_id
声明没有。我鼓励您重新阅读代码并自己发现错误,但似乎您需要@littlefoot来指出它。要成为一名优秀的程序员,你必须掌握的一项重要技能是用冷静的眼光阅读自己的代码。你不可能把你写的所有东西都发到这个网站上,希望有陌生人能帮你调试。所以,为了将来的参考,每当Oracle抛出PLS-00103:遇到这个符号时。。。当预期出现以下情况之一时:
表示您的代码包含语法错误。因此,请查看指示行中的代码-第2行的错误:
-并查看错误所在。有时,语法错误会出现在前一行或后一行,但它总是锚定在Oracle提供给您的行上。