以下的一些例子是基于scott用户下的emp表的数据,一和二使用的均为in,out参数,最后一个综合练习使用了 in out参数

一.存储过程

1.创建无参的存储过程示例  ------ hello

注意存储过程中的PLSQL部分没有了declare

 create or replace procedure hello
as
begin
dbms_output.put_line('ok');
end;
/

2.如何调用?

第一种方式 -----  exec(或者是execute) hello;

第二种方式 ----- 使用PLSQL调用

    begin

    hello;
  end;
  /

3.创建有参存储过程raiseSalary(编号),为指定员工涨10%的工资(员工编号从键盘接收)(in的用法)

注意:1.涉及到10%这种带有百分号的运算时一定要转换成相应的数字,例如:0.1

2.in 表示是何种参数,为默认值,可省略

   3.&符号的使用,输入时如果是字符串不要忘记' ',输完不要多加分号

 --创建
create or replace procedure raiseSalary(pempno in number)
as
begin
update emp set sal = sal * 1.1 where empno = pempno;
end;
/
--调用(exec raiseSalary(&empno);)
begin
raiseSalary(&empno);
end

4.创建有参存储过程findEmpNameAndSalAndJob(编号),查询指定编号员工的的姓名,职位,月薪,返回多个值(out的用法)

注意:用 || 连接字符串,以及使用 ' '表示字符串

 --创建
create or replace procedure findEmpNameAndSalAndJob(pempno emp.empno%type,pname out emp.ename%type,pjob out emp.job%type,psal out emp.sal%type)
as
begin
select ename,job,sal into pname,pjob,psal from emp where empno = pempno;
end;
/
--调用
declare
---创建这三个变量去接收传出来的参数
pname emp.ename%type;
pjob emp.job%type;
psal emp.sal%type;
begin
findEmpNameAndSalAndJob(&empno,pname,pjob,psal);
dbms_output.put_line(pname || '----' || pjob || '-----' || psal );
end;
/

总结:从上面的几个例子可以看出如果有存储过程有参数传出的话,那么使用PLSQL调用较好,如果无传出参数的话用exec调用

二.存储函数

  存储函数必须有且只有一个返回值和参数类型

1.创建并调用无参的存储过程示例

注意:1.可以看到创建存储函数时的PLSQL部分仍然没有declare

   2.调用存储函数时由于函数有返回值所以声明了一个变量去接收

 --创建
create or replace function getName return varchar2
as
begin
return 'wyc';
end;
/ --调用
declare
name varchar2(10);
begin
name := getName();
dbms_output.put_line(name);
end;
/

2.创建有参存储函数findEmpIncome(编号),查询指定员工编的年收入(年薪+佣金)(in的用法,默认是in)

 --创建
create or replace function findEmpIncome(pempno in number) return number
as
income emp.sal%type;
begin
-- 考虑到emp表中一些员工的佣金为null
select sal + NVL(comm,0) into income from emp where empno = pempno;
return income;
end;
/
--调用
declare
income emp.sal%type;
begin
income := findEmpIncome(&empno);
dbms_output.put_line('收入是' || income);
end;
/

3.创建有参存储函数findEmpNameAndJobAndSal(编号),查询指定编号员工的的姓名(return),职位(out),月薪(out),返回多个值

前面说过存储函数只能有一个返回值,如果有多个返回值的话要结合out参数进行处理

 --创建函数
create or replace function findEmpNameAndJobAndSal(pempno in number,pjob out varchar2,psal out varchar2)
return varchar2
as
pname emp.ename%type;
begin
select ename,job,sal into pname,pjob,psal from emp where empno = pempno;
return pname;
end;
/
--调用函数
declare
pjob emp.job%type;
psal emp.sal%type;
pname emp.ename%type; --- 接收返回值
begin
pname :=findEmpNameAndJobAndSal(&empno,pjob,psal);
dbms_output.put_line(pname || '-----' || pjob || '-----' || psal);
end;
/

总结:存储函数与存储过程有些类似但又有不同,只有一个返回值时适合使用存储函数,有多个返回值或者没有返回值时适合使用存储过程

3.综合练习  --- 分别使用存储过程及存储函数计算个人税收(存储函数使用到了in out参数)

1.存储过程计算个人所得税

 --创建存储过程 (注意10%一定要写成0.1)
create or replace procedure get_rax(psal in number,rax out number)
as
money number(6);
begin
money := psal - 3500;
if money <= 1500 then
rax := money * 0.03 - 0;
elsif money <= 4500 then
rax := money * 0.1 - 105;
elsif money <= 9000 then
rax := money * 0.2 - 555;
elsif money <= 35000 then
rax := money * 0.25 - 1005;
elsif money <= 55000 then
rax := money * 0.3 - 2755;
elsif money <= 80000 then
rax := money * 0.35 - 5505;
else
rax := money * 0.45 - 13505;
end if;
end;
/
--调用
declare
rax number(20);
begin
get_rax(&sal,rax);
dbms_output.put_line('您要交的税为 : ' || rax);
end;
/

2.存储函数

pname要回传给调用者,从而输出姓名

 create or replace function get_rax2(pname in out varchar2,psal in number)
return number
as
money number(6);
rax number(20);
begin
money := psal - 3500;
if money <= 1500 then
rax := money * 0.03 - 0;
elsif money <= 4500 then
rax := money * 0.1 - 105;
elsif money <= 9000 then
rax := money * 0.2 - 555;
elsif money <= 35000 then
rax := money * 0.25 - 1005;
elsif money <= 55000 then
rax := money * 0.3 - 2755;
elsif money <= 80000 then
rax := money * 0.35 - 5505;
else
rax := money * 0.45 - 13505;
end if;
return rax;
end;
/ --调用存储函数
declare
rax number(20);
name varchar2(10);
begin
name := &name;
rax := get_rax2(name,&sal);
dbms_output.put_line('尊敬的' || name || ',您应交的税为 :' || rax);
end;
/

如果还有问题的话,后续再进行补充 ^_^

Oracle 存储过程以及存储函数的更多相关文章

  1. oracle存储过程和存储函数&触发器

    oracle存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程,存储函数 存储过程和存储函数的相同点:完成特定功能的程序 存储过程和存储函数的区别:是否用return语句返回值 ...

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

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

  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)

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

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

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

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

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

  8. Oracle存储过程和自定义函数

    新博客文章链接,欢迎大家评论探讨 概述 存储过程和存储函数是指存储在数据库中供所有用户程序调用的子程序叫存储过程.存储函数. 异同点: 存储过程和存储函数的相同点:完成特定功能的程序. 存储过程和存储 ...

  9. Oracle存储过程和自定义函数笔记

    学习地址:https://www.imooc.com/learn/370 存储过程和存储函数定义:指存储在数据库中供所有用户程序调用的子程序叫做存储过程 .存储函数. 相同点:完成特定功能的程序.区别 ...

随机推荐

  1. Codeforces Round #261 (Div. 2)459D. Pashmak and Parmida&#39;s problem(求逆序数对)

    题目链接:http://codeforces.com/contest/459/problem/D D. Pashmak and Parmida's problem time limit per tes ...

  2. HDU 1013.Digital Roots【模拟或数论】【8月16】

    Digital Roots Problem Description The digital root of a positive integer is found by summing the dig ...

  3. Java中File的使用

    File 代表文件或者目录的类 构造函数 File(File parent,String child)---代表了指定父目录下的指定的子文件或者子目录 File(String pathname)--- ...

  4. gearman学习笔记1

    1.简介       gearman是一个分布式开发框架,适合处理一些必须处理但是不影响主流程的操作,比如保存日志.发送邮件.缩略图片等.最早是基于perl语言的,2008年发布的时候改为C++语言开 ...

  5. springboot 入门四-时间类型处理

    springboot 自带了jackson来处理时间,但不支持jdk8 LocalDate.LocalDateTime的转换. 对于Calendar.Date二种日期,转换方式有二种: 一.统一app ...

  6. C图形库Easyx的使用

    学习Eaxy X图形库后我的成果: 花了一周时间做出并完善了Flappy Bird,目前功能如下: 1. 背景的显示 2. 加入小鸟image 3. 小鸟自由下落,按空格键/鼠标右键后上升 4. 加入 ...

  7. MySQL数据库 Event 定时执行任务.

    一.背景 由于项目的业务是不断往前跑的,所以难免数据库的表的量会越来越庞大,不断的挤占硬盘空间.即使再大的空间也支撑不起业务的增长,所以定期删除不必要的数据是很有必要的.在我们项目中由于不清理数据,一 ...

  8. c#$用法

    为什么会出现$符号,c#6.0才出现的新特性 var s = string.Fromat("{0}+{1}={2}",12,23,12+23) 用起来必须输入string.From ...

  9. bzoj 4813: [Cqoi2017]小Q的棋盘

    Description 小Q正在设计一种棋类游戏.在小Q设计的游戏中,棋子可以放在棋盘上的格点中.某些格点之间有连线,棋子只能 在有连线的格点之间移动.整个棋盘上共有V个格点,编号为0,1,2-,V- ...

  10. 2.sass变量、嵌套、混合(mixin)、继承拓展、@import、comment

    变量.嵌套.混合(mixin).继承拓展.@import.comment 变量的意义 在sass里我们可以定义多个变量来存放颜色.边框等等的样式,这样就可以在下面想要使用样式的时候使用变量了 这样的优 ...