使用CALL和EXEC調用存儲過程的區別

使用CALL調用存儲過程,不能使用名稱參數,同時也會忽略未處理的ORA-01403:NO DATA FOUND錯誤。而使用EXEC的話,可以使用名稱參數,同時會拋出未處理的ORA-01403,使用BEGIN ... END效果與EXEC相同。例子如下

 

創建一個簡單的存儲過程:

create or replace procedure proc_update_salary( p_emp_id number, p_increment number default 0.1 -- 可以不傳入p_increment的參數值,默認值使用0.1 ) is v_old_salary number; begin select salary into v_old_salary from employees where employee_id = p_emp_id; if v_old_salary < 10000 then update employees set salary = salary + salary * p_increment where employee_id = p_emp_id; end if; end;

 

測試

call proc_update_salary(198); -- 正常運行 call proc_update_salary(1908, 0.2); -- 沒有拋出ORA-01043 call proc_update_salary(p_emp_id=>198); -- 不能執行,ORA-00907: missing right parenthesis exec proc_update_salary(p_increment=>0.2, p_emp_id=>1908); -- 可以執行,但拋出ORA-01043 begin proc_update_salary(198, 0.2); -- 正確運行 end;

 

你可能感兴趣的:(Oracle)