oracle存储过程和存储函数

指存储在数据库中供所有用户程序调用的子程序叫存储过程,存储函数

存储过程和存储函数的相同点:完成特定功能的程序

存储过程和存储函数的区别:是否用return语句返回值

=========================创建和使用存储过程=============================

用create procedure命令建立存储过程和存储函数

语法:

create [or replace] procedure 过程名(参数列表)

as

PLSQL子程序体;

实例:带参数的存储函数

create or replace procedure RaiseSalry(eno in number)

as

psal emp.sal%type;

begin

select sal into psal from emp where EMPNO=eno;

update emp set sal = sal +100 where EMPNO=eno;

DBMS_OUTPUT.PUT_LINE('涨工资前的薪水'||psal||'涨工资后的薪水'||(psal+100));

end;

/

===========================创建存储函数的语法============================

create [or replace] function 函数名(参数列表)

return 函数值类型

as

plsql子程序体;

实例:查询某个员工的年收入

create or replace function queryempincome(eno in number)

return number

as

--定义变量保存员工薪水和奖金

psal emp.sal%type;

pcomm emp.comm%type;

begin

--得到员工的月薪和奖金

select sal,comm into psal,pcomm from emp where empno=eno;

--直接返回年收入

return psal*12+pcomm;

end;

/

===========================in和out参数=============================

过程和函数可以通过out指定一个或多个输出参数,我们可以利用out参数,在过程和函数中实现多个返回值

原则:如果只有一个返回值,就用存储函数,否则,就用存储过程

实例:out参数,查询员工姓名,月薪和职位

create or replace procedure queryempinform(eno in number,

pname out varchar2,

psal out number,

pjob out varchar2)

as

begin

--得到该员工的姓名,月薪和职位

select ename,sal,ejob into pname,psal,pjob from emp where empno=eno;

end;

/

==========================在out参数中使用光标=========================

案例:查询某个部门中所有员工的所有信息

--包头:声明

create or replace package mypackage as

type empcursor is ref cursor;

procedure queryEmpList(dno in number,empList out empcursor);

end mypackage;

--包体:实现包头声明的所有方法

create or replace package body mypackage as

procedure queryEmpList(dno in number,empList out empcursor)

as

begin

open empList for select * from emp where deptno=dno;

end queryEmpList;

end mypackage;

oracle触发器

========================什么是触发器(trigger)==========================

①数据库触发器是一个与表相关联的,存储的pl/sql程序

②没当一个特定的数据操作语句(insert,update,delete)在指定的表上发出时,oracle自动的执行触发器中定义的语句序列

如何创建触发器

create trigger saynewemp

after insert

on emp

declare

begin

dbms_output.put_line('成功插入新员工');

end;

/

============================触发器应用场景==============================

1.复杂的安全性检查

2.数据确认

3.实现审计功能

4.完成数据的备份和同步

==============================触发器的语法==============================

创建触发器的语法

create [or replace] trigger 触发器名

{before|after}

{delete|insert|update[of 列名]}

on 表名

[for each row [when(条件)]]

plsql块

==============================触发器的类型==============================

语句级触发器:在指定的操作语句之前或之后执行一次,不管这条语句影响了多少行

行级触发器:触发语句作用的每一条记录都被触发。在行级触发器中使用:old和:new伪记录变量,识别值得状态

=================================案例=================================

触发器应用场景一:实施复杂的安全性检查

禁止在非工作时间插入新员工

1,周末:to_char(sysdate,'day')in('星期六','星期日')

2,上班前,下班后:to_number(to_char(sysdate,'hh24')) not between 9 and 18

create or replace trigger securityemp

before insert

on emp

begin

if to_char(sysdate,'day')in('星期六','星期日') or

to_number(to_char(sysdate,'hh24')) not between 9 and 18 then

--禁止insert新员工

raise_application_error(-20001,'禁止在非工作时间插入新员工');

end if;

end;

/

触发器应用场景二:数据的确认

涨工资不能越涨越少

create or replace trigger checksalary

before update

on emp

for each row

begin

if :new.sal<:old.sal then

raise_application_error(-20002,'涨后的薪水不能少于涨前的薪水,涨后的薪水:'||:new.sal||'涨前的薪水'||:old.sal);

end if;

end;

/ 触发器应用场景三:数据库审计

创建基于值的触发器

给员工涨工资,当涨后的薪水超过6000,审计该员工的信息

创建表用于保存审计信息

create table audit_info

(

information varchar2(200)

);

create or replace trigger do_audit_emp_salary

after update

on emp

for each row

begin

--当涨后的薪水大于5000,插入审计信息

if :new.sal>5000 then

insert into audit_info values(:new.empno||' '||new.ename||'

'||:new.sal);

end if;

end;

/

触发器应用场景四:数据的备份和同步

利用触发器实现数据的同步部分(分布式数据库)

当给员工涨工资后自动备份到备份表中

create or replace trigger sync_salary

after update

on emp

for each row

begin

--当主表更新后,自动更新备份表

update emp_back set sal=:new.sal where empno=:new.empno;

end;

/

oracle存储过程和存储函数&触发器的更多相关文章

  1. oracle存储过程和存储函数

    存储过程 1.存储过程简介 下面先来简单介绍一下oracle的存储过程的语法,如下: create or replace procedure Tony_Process ( num in number, ...

  2. Oracle 存储过程以及存储函数

    以下的一些例子是基于scott用户下的emp表的数据,一和二使用的均为in,out参数,最后一个综合练习使用了 in out参数 一.存储过程 1.创建无参的存储过程示例  ------ hello ...

  3. oracle存储过程与存储函数的区别和联系

    相同点:1.创建语法结构相似,都可以携带多个传入参数和传出参数.      2.都是一次编译,多次执行. 不同点:1.存储过程定义关键字用procedure,函数定义用function. 2.存储过程 ...

  4. Oracle03——游标、异常、存储过程、存储函数、触发器和Java代码访问Oracle对象

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7476717.html 1.游标(光标)Cursor 在写java程序中有集合的概念,那么 ...

  5. Oracle学习2 视图 索引 sql编程 游标 存储过程 存储函数 触发器

    ---视图 ---视图的概念:视图就是提供一个查询的窗口,来操作数据库中的数据,不存储数据,数据在表中. ---一个由查询语句定义的虚拟表. ---查询语句创建表 create table emp a ...

  6. 编程开发之--Oracle数据库--存储过程和存储函数(2)

    上一小结我们简单介绍了存储过程和存储函数,对存储过程和存储函数有了一个基本的了解,接下来介绍在java程序中如何调用我们创建的存储过程和存储函数 1.在应用程序中调用我们的存储过程 创建一个简单的Ja ...

  7. 存储过程,存储函数(Oracle)

    存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程.存储函数. 存储过程和存储函数的区别? 存储函数:可以通过return 语句返回函数值. 存储过程:不能 除此之外我们可以认为 ...

  8. 编程开发之--Oracle数据库--存储过程和存储函数(1)

    1.存储过程和存储函数 描述:指存储在数据库中供所有用户程序调用的子程序叫做存储过程.存储函数 区别:存储函数可以通过return子句返回一个函数的值 (1)存储过程 语法:create [or re ...

  9. mysql 存储过程和存储函数

    14.1.1 创建存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristi ...

随机推荐

  1. 非对称加密, 助记词, PIN, WIF

    一钱包 1.1非对称加密, 助记词, PIN, WIF, 地址 1.1.1 非对称加密算法 非对称加密算法, 加密与解密使用不同的KEY, 我们分别称为私钥与公钥,其中可以通过私钥生成公钥 在比特币中 ...

  2. PKU《程序设计》专项课程_递归汉诺塔问题

    取自coursera.org上公开课北京大学<C程序设计进阶> 递归调用注意的点 1.关注点放在求解的目标上,递推是,目标放在开头 2.找到第N次和第(N-1)次之间的关系,通项公式 3. ...

  3. org.springframework.orm.hibernate3.HibernateSystemException:

    org.springframework.orm.hibernate3.HibernateSystemException: The database returned no natively gener ...

  4. POJ - 1830:开关问题 (开关问题-高斯消元-自由元)

    pro:有N个相同的开关,每个开关都与某些开关有着联系,每当你打开或者关闭某个开关的时候,其他的与此开关相关联的开关也会相应地发生变化,即这些相联系的开关的状态如果原来为开就变为关,如果为关就变为开. ...

  5. s21day23 python笔记

    s21day23 python笔记 一.内容回顾及补充 字符串格式化 %s # 示例一:特别注意:最后的右括号前面必须有逗号(,) msg = '我是%s,年龄%s'%('alex',19,) # 元 ...

  6. PA教材提纲 TAW12-2

    Unit1 Adjustment of SAP Standard Software(SAP标准软件修改) 1.1 Adjusting SAP Standard Software(如何修改SAP标准软件 ...

  7. 增删改查js

    -----------------------------------------------------一---------------------------------------------- ...

  8. C++实现简单学生管理系统

    在网上看到的一个C++的小项目,我自己码了一遍,然后记录下我的理解以及像我这种菜鸟在整个过程中产生的问题. 我将我知道的尽可能详细的写下来,如有错误请联系我哈,QQ:920209178. 原文地址:h ...

  9. android开发解决Error:Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'. > java.lang.RuntimeException: java.lang.RuntimeException: c.....

    网上常见的方法我都试过,都没能解决,偶然看到的一个方法解决了,在这了记录一下. 在App目录下的build.gradle的android{ ...  ....}中添加如下代码,即可解决.(xx.xx. ...

  10. 关于 lua table表存储函数且运用

    --table 是lua的一种数据结构用来帮助我们创建不同的数据类型.如:数组和字典--lua table 使用关联型数组,你可以用任意类型的值来做数组的索引,但这个值不能是nil--lua tabl ...