日期:2014-05-16  浏览次数:20780 次

请问这个要怎么改啊
declare
v_empno emp.empno%type;
v_ename emp.ename%type;
v_sal emp.sal%type;
v_deptno emp.deptno%type;
begin
select empno,ename,sal,deptno into v_empno,v_ename,v_sal,v_deptno from emp where 

ename='Smith';
dbms_output.put_line(v_empno||' '||v_ename||' '||v_sal||' '||v_deptno);
exception
when no_data_found then
insert into emp(empno,ename,sal,deptno) values(2012,'Smith',7500,50);
when too_many_rows then
for v_emp in (select * from emp where ename='Smith') loop
dbms_output.put_line(v_emp.empno||' '||v_emp.ename||' '||v_emp.sal||' 

'||v_emp.hiredate||' '||v_emp.deptno);
end loop;
end;


------解决方案--------------------
是不是这个地方做了外键约束,你这里的50没有在主表定义
insert into emp(empno,ename,sal,deptno) values(2012,'Smith',7500,50);