Oracle存储函数,存储过程
一、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存储函数,存储过程的更多相关文章
- PL/SQL轻量版(四)——存储函数/存储过程与触发器
概述 ORACLE 提供可以把 PL/SQL 程序存储在数据库中,并可以在任何地方来运行它.这样就叫存储过程或函数.过程和函数统称为 PL/SQL 子程序,他们是被命名的 PL/SQL 块,均存储在数 ...
- Oracle存储函数jdbc调用
package com.jckb.procedure; import java.sql.CallableStatement; import java.sql.Connection; import ja ...
- ORACLE 存储函数
前奏: 必要的概念: ORACLE 提供能够把 PL/SQL 程序存储在数据库中.并能够在不论什么地方来运行它.这样就叫存储过 程或函数. 过程和函数统称为 PL/SQL 子程序.他们是被命名的 PL ...
- oracle存储函数实例
CREATE OR REPLACE PROCEDURE "PROC_INS_DAY_DOCTOR_LL"(v_date in VARCHAR) is --PROC_INS_DAY_ ...
- oracle 游标/函数/存储过程/触发器 表空间
--存储过程,循环create or replace procedure delTables(ename t_emp.ename%TYPE)AScon number;i NUMBER := 1;tab ...
- 关于oracle的函数,存储过程,触发器,序列,视图,左右连接一些的应用 带案例
CREATE TABLE STUDENT( --创建学生表 ID NUMBER(10) PRIMARY KEY, --主键ID NAME VARCHAR2(20), CLASSNAME VA ...
- oracle 存储函数,更新库存
create procedure PRO_update_Goods_group_stock is v_min_stock , ); v_gg_stock , ); v_goods_no number; ...
- oracle存储过程和存储函数&触发器
oracle存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程,存储函数 存储过程和存储函数的相同点:完成特定功能的程序 存储过程和存储函数的区别:是否用return语句返回值 ...
- Oracle的基本语法,存储函数及触发器
1.PL/SQL PL/SQL是Oracle对 ql语言的过程化扩展,指在 SQL 命令语言中增加了过程处理语句,使SQL语言具有过程处理能力.把 SQL 语言的数据操纵能 力与过程语言的数据 ...
随机推荐
- IDEA启动springboot项目一直build
启动main方法后,项目一直在不断的build,期间截了两张一闪而过的提示 我用的是Run Dashboard面板,不论是通过删除configuration,rebuild,删除IDEA缓存都没有效果 ...
- Laravel 5.8 添加服务层
参考网址:https://blog.csdn.net/dmt742055597/article/details/97192177#Laravel58service_1
- JS高级特性
一.JavaScript的同源策略 参考链接:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Same_origin_policy_fo ...
- day 38 MySQL之单表查询
MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER ...
- PAT甲级——A1096 Consecutive Factors【20】
Among all the factors of a positive integer N, there may exist several consecutive numbers. For exam ...
- PAT甲级——【牛客A1005】
题目描述 Behind the scenes in the computer's memory, color is always talked about as a series of 24 bits ...
- docker 整理
管理 docker批量删除容器.镜像 1.删除所有容器 docker rm `docker ps -a -q` 1.1 按条件删除容器 删除包含某个字段 ,镜像名或容器名均可, 例如删除 zhy* ...
- Ceisum官方教程1 -- 开始
原文地址:https://cesium.com/docs/tutorials/getting-started/ 学会使用全球地形.影像.3d tile(模型切片).地理编码创建一个Cesium程序. ...
- 016-WebDriver API(2)
1. 多表单切换 WebDriver只能在一个页面上对元素进行识别和定位,无法直接定位frame/iframe表单内嵌页面上的元素,这是就需要通过switch_to.frame()方法将当前定位的主体 ...
- docker启动redis设置密码
docker run --name picker-redis -p 6379:6379 -d redis --requirepass "认证密码"