同一个代码为什么在sql中可以运行在pl/sql中不可以呢????
declarecursorcur_emp(var_jobinvarchar2:='SALESMAN')isselectempno,ename,salfromscott.e...
declare
cursor cur_emp (var_job in varchar2:='SALESMAN')
is select empno,ename,sal
from scott.emp
where job=var_job;
type record_emp is record
(
var_empno emp.empno%type,
var_ename emp.ename%type,
var_sal emp.sal%type
);
emp_row record_emp;
begin
open cur_emp('MANAGER');
fetch cur_emp into emp_row;
while cur_emp%found loop
dbms_output.put_line(emp_row,var_ename||'的编号是'
||emp_row.var_empno||',工资是'||emp_row.var_sal);
fetch cur_emp into emp_row;
end loop;
close cur_emp;
end;
ORA-06550: 第 8 行, 第 11 列:
PLS-00201: 必须声明标识符 'EMP.EMPNO'
ORA-06550: 第 6 行, 第 1 列:
PL/SQL: Item ignored
ORA-06550: 第 16 行, 第 20 列:
PLS-00597: INTO 列表中的表达式 'EMP_ROW' 类型错误
ORA-06550: 第 16 行, 第 1 列:
PL/SQL: SQL Statement ignored
ORA-06550: 第 18 行, 第 30 列:
PLS-00201: 必须声明标识符 'VAR_ENAME'
ORA-06550: 第 18 行, 第 1 列:
PL/SQL: Statement ignored
ORA-06550: 第 20 行, 第 20 列:
PLS-00597: INTO 列表中的表达式 'EMP_ROW' 类型错误
ORA-06550: 第 20 行, 第 1 列:
PL/SQL: SQL Statement ignored 展开
cursor cur_emp (var_job in varchar2:='SALESMAN')
is select empno,ename,sal
from scott.emp
where job=var_job;
type record_emp is record
(
var_empno emp.empno%type,
var_ename emp.ename%type,
var_sal emp.sal%type
);
emp_row record_emp;
begin
open cur_emp('MANAGER');
fetch cur_emp into emp_row;
while cur_emp%found loop
dbms_output.put_line(emp_row,var_ename||'的编号是'
||emp_row.var_empno||',工资是'||emp_row.var_sal);
fetch cur_emp into emp_row;
end loop;
close cur_emp;
end;
ORA-06550: 第 8 行, 第 11 列:
PLS-00201: 必须声明标识符 'EMP.EMPNO'
ORA-06550: 第 6 行, 第 1 列:
PL/SQL: Item ignored
ORA-06550: 第 16 行, 第 20 列:
PLS-00597: INTO 列表中的表达式 'EMP_ROW' 类型错误
ORA-06550: 第 16 行, 第 1 列:
PL/SQL: SQL Statement ignored
ORA-06550: 第 18 行, 第 30 列:
PLS-00201: 必须声明标识符 'VAR_ENAME'
ORA-06550: 第 18 行, 第 1 列:
PL/SQL: Statement ignored
ORA-06550: 第 20 行, 第 20 列:
PLS-00597: INTO 列表中的表达式 'EMP_ROW' 类型错误
ORA-06550: 第 20 行, 第 1 列:
PL/SQL: SQL Statement ignored 展开
2个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询