本文主要是介绍初次了解存储过程和存储函数和触发器的例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
--传参的存储过程
create or replace procedure addSalTo2(eno in number, num in number)asbeginupdate emp set sal = sal + num where empno = eno;dbms_output.put_line(eno || '涨了' || num || '工资');end;begin
addsalTo2(7499, 400);
end;--返回值的存储过程
create or replace procedure queryEmpNameSal(eno in number, pname out varchar2, psal out number) as
vsal emp.sal %type;
begin
select ename, sal into pname, psal from emp where empno = eno;end;--返回值的存储函数
create or replace function queryEmpNameSal2(eno in number, pname out varchar2, psal out number)return varchar2as
vsal emp.sal %type;
begin
select ename, sal into pname, psal from emp where empno = eno; return pname;
end;--一般只有一个返回值的优先使用存储函数,其他都用存储过程--触发器(非工作时间) 语句级别,,
create or replace trigger mytiggerbefore inserton empdeclare
--变量beginif not(to_number(to_char(sysdate, 'hh24')) between 9 and 17) thenraise_application_error(-20004, '现在是非工作时间,不能插入数据!');end if;end;--行级别的触发器
create or replace trigger checkSalbefore updateon empfor each rowdeclarebegin
if :new.sal <= :old.sal then raise_application_error(-20000, '涨工资不能越长越少!');
end if;
end;--闪回
show recyclebin --查看回收站
flashback table tableName to before drop;--恢复删除的表select * from emp;
这篇关于初次了解存储过程和存储函数和触发器的例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!