一、Oracle存储函数:存储的PL/SQL语法块,完成特定的功能。
1、语法: 函数关键字: function

(1)创建函数

CREATE [OR REPLACE] FUNCTION  <function name> [(param1,param2)] RETURN <datatype>  IS|AS
[local declarations]
declare
.....
BEGIN
Executable Statements;
RETURN result;
EXCEPTION
Exception handlers;
END;

(2)调用函数

--调用
--1.写查询调用
select fun1 from dual;
--2.PL/SQL语法块调用
declare
my_name varchar2(20);
begin
my_name := fun1;
dbms_output.put_line(my_name);
end;

2、函数的参数模式

(1)输入参数 in:
--有参的函数

create or replace function fun2(s_id number) return varchar2
as
t_name varchar2(20);
begin
  select sname into t_name from stu where sid = s_id;
  return t_name;
end; select fun2(4) from dual;

例:输入in与输出out参数

create or replace function fun2(t_id number,t_name out varchar2) return varchar2
as
begin
select sname into t_name from stu where sid = t_id;
return t_name;
end; declare
stu_name varchar2(20);
my_name varchar2(20);
begin
stu_name := fun2(1,my_name);
dbms_output.put_line(stu_name);
end;

(2)in out参数

create or replace function fun3(num1 in out number,num2 in out number) return varchar2
as
t_temp number;
begin
t_temp := num1;
num1 := num2;
num2 := t_temp;
return num1 + num2;
end; declare
numa number := 10;
numb number := 20;
numc number;
begin
dbms_output.put_line(numa || '--'||numb);
numc := fun3(numa,numb);
dbms_output.put_line(numa || '--'||numb);
end;

注意:1、参数要为变量,定值返回时无法赋值。

   2、函数return要有返回值 就是end之前return语句,当调用函数时还需要声明一个变量接受返回值,即使没有使用。

规范:参数v开头,如v_name,临时变量t_name (temp_name)。

二、Oracle存储过程

Oracle存储过程:将执行的过程存储起来就是存储过程。
1、语法 :存储过程关键字 procedure

CREATE [OR REPLACE] procedure <procedure name> [(param1,param2)] IS|AS
[local declarations]
BEGIN
Executable Statements;
EXCEPTION
Exception handlers;
END;

参数用法和存储函数一样
调用:略有不同
1.PL/SQL语法块
2.命令行 使用 execute 命令去调用  如 execute procedure_name(param1,param2);

三、区别

存储过程和存储函数的区别:
1、存储函数有返回值,存储过程没有返回值
2、调用方式略有不同.. 函数和过程都支持 pl/sql调用
      函数支持 (select)查询直接调用 过程支持 execute 命令调用
3、存储过程是否可以代替存储函数? 可以代替,但是兼容性问题,存储过程后出现 。之前的项目要支持。

 存储函数有时更加方便,可以直接select查询调用,

--视图配合存储函数

create or replace view emp_v as
select e.*,yearsal(e.sal,e.comm) as "年薪" from emp e;
--计算年薪的存储函数
create or replace function yearsal(v_sal number,v_comm number) return number as
t_year number;
begin
t_year := v_sal*12+nvl(v_comm,0);
return t_year;
end;

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

  1. PL/SQL轻量版(四)——存储函数/存储过程与触发器

    概述 ORACLE 提供可以把 PL/SQL 程序存储在数据库中,并可以在任何地方来运行它.这样就叫存储过程或函数.过程和函数统称为 PL/SQL 子程序,他们是被命名的 PL/SQL 块,均存储在数 ...

  2. Oracle存储函数jdbc调用

    package com.jckb.procedure; import java.sql.CallableStatement; import java.sql.Connection; import ja ...

  3. ORACLE 存储函数

    前奏: 必要的概念: ORACLE 提供能够把 PL/SQL 程序存储在数据库中.并能够在不论什么地方来运行它.这样就叫存储过 程或函数. 过程和函数统称为 PL/SQL 子程序.他们是被命名的 PL ...

  4. oracle存储函数实例

    CREATE OR REPLACE PROCEDURE "PROC_INS_DAY_DOCTOR_LL"(v_date in VARCHAR) is --PROC_INS_DAY_ ...

  5. oracle 游标/函数/存储过程/触发器 表空间

    --存储过程,循环create or replace procedure delTables(ename t_emp.ename%TYPE)AScon number;i NUMBER := 1;tab ...

  6. 关于oracle的函数,存储过程,触发器,序列,视图,左右连接一些的应用 带案例

    CREATE TABLE STUDENT( --创建学生表  ID NUMBER(10) PRIMARY KEY,   --主键ID  NAME VARCHAR2(20),  CLASSNAME VA ...

  7. oracle 存储函数,更新库存

    create procedure PRO_update_Goods_group_stock is v_min_stock , ); v_gg_stock , ); v_goods_no number; ...

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

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

  9. Oracle的基本语法,存储函数及触发器

    1.PL/SQL    PL/SQL是Oracle对 ql语言的过程化扩展,指在 SQL 命令语言中增加了过程处理语句,使SQL语言具有过程处理能力.把 SQL 语言的数据操纵能  力与过程语言的数据 ...

随机推荐

  1. 微信H5支付签名校验错误

    参数一定按照我得顺序写,这样可以不用排序,签名在图二. H5支付最坑的一点就是文档坑爹!!!文档中有一个场景信息字段写的是必填,实际上是不需要的!!因为这个字段找了一下午bug,用签名校验工具是成功的 ...

  2. SpringBoot 05_集成SpringDataJpa

    你还在为项目的集成头疼吗?你还在为管理大量的配置文件烦恼吗?如果是,用SpringBoot吧!今天主要介绍如果在SpringBoot的基础上创建一个集成了SpringDataJpa的项目,至于Spri ...

  3. Git命令使用和配置

    git config --global user.name "your name" git config --global user.email "your email& ...

  4. python面向对象应用-1

    #猫 定义类 class Cat: type = '猫' #通过__init__初始化的特征 def __init__(self,nickname,age,color): self.nickname ...

  5. wpf布局控件总结

    首先要认识到wpf所有的布局控件都继承自Panel类,Panel类又继承自其他类.继承关系如下: 一.StackPanel布局面板 1.该面板在单行或者单列中以堆栈的形式放置其子元素. 默认情况下,S ...

  6. elasticsearch 中文API 删除(四)

    删除API 删除api允许你通过id,从特定的索引中删除类型化的JSON文档.如下例: DeleteResponse response = client.prepareDelete("twi ...

  7. mapreduce.Job: Running job: job_1553100392548_0001

    这几天一直在尝试一个mapreduce的例子,但是一直都是卡在mapreduce.Job: Running job: job_1553100392548_0001,查看日志也不报错,查看每个配置文件没 ...

  8. 简单的sequence unpacking

    t = (1, 2, ‘hl’) x, y, z = t 上述方法可用于任何sequence

  9. NOIP2017普及组初赛总结

    去年,我普及组复赛翻车,居然没进一等奖,于是,今年,我只能再做一次普及组. 这次初赛我93.5分,居然是中山市第一--(中山市太弱了?) 其实我觉得我没考好. 比赛时第二题(计算机存储数据的基本单位是 ...

  10. 微信回调校验失败兼容php7

    今天在移动微信支付的代码的时候,发现校验失败,之前好好的,一点点打印了,顺着微信校验程序打印看结果,发现  $xml = $GLOBALS['HTTP_RAW_POST_DATA'];; 接收到的数据 ...