ORACLE 存储函数
- 前奏:
- 必要的概念:
- ORACLE 提供能够把 PL/SQL 程序存储在数据库中。并能够在不论什么地方来运行它。这样就叫存储过
- 程或函数。
- 过程和函数统称为 PL/SQL 子程序。他们是被命名的 PL/SQL 块,均存储在数据库中,并
- 通过输入、输出參数或输入/输出參数与其调用者交换信息。过程和函数的唯一差别是函数总向调
- 用者返回数据。而过程则不返回数据。
- 1:创建函数
- CREATE [OR REPLACE] FUNCTION function_name
- [ (argment [ { IN | IN OUT }] Type,
- argment [ { IN | OUT | IN OUT } ] Type ]
- [ AUTHID DEFINER | CURRENT_USER ]
- RETURN return_type
- { IS | AS }
- <类型.变量的说明>
- BEGIN
- FUNCTION_body
- EXCEPTION
- 其他语句
- END;
- 2:说明:
- 1) OR REPLACE 为可选. 有了它, 能够或者创建一个新函数或者替换同样名字的函数, 而不会出现冲突
- 2) 函数名后面是一个可选的參数列表, 当中包括 IN, OUT 或 IN OUT 标记. 參数之间用逗号隔开. IN 參数标记表示传递给函数的值在该函数运行中不改变OUT 标记表示一个值在函数中进行计算并通过该參数传递给调用语句; IN OUT 标记表示传递给函数的值能够变化并传递给调用语句. 若省略标记, 则參数隐含为 IN。
- 3) 由于函数须要返回一个值, 所以 RETURN 包括返回结果的数据类型.
- 3:例题:
- --存储函数结构
- create function func_name(dept_id number , salary number)
- return number
- is
- --函数使用过程中 须要声明的变量 记录类型 cursor
- begin
- --函数的运行体
- exception
- --处理函数运行过程中异常
- end;
- --例题1 写一个返回hellow world的function
- create or replace function hello_func(temp varchar2)
- return varchar2
- is
- begin
- return 'hello world'|| temp;
- end;
- --调用函数:
- begin
- dbms_output.put_line(hello_func);
- end;
- select hello_func('cui') from dual;
- --例二 写一个返回系统时间的函数 假设函数没有形參 切勿加()
- create function get_sysdate
- return date
- is
- v_date date;
- begin
- v_date := sysdate;
- return v_date;
- end;
- select get_sysdate() from dual;
- --创建两个參数相加的 存储函数
- create function add_func(temp_A number , temp_B number)
- return number
- is
- temp_sum number(10);
- begin
- temp_sum := temp_A + temp_B;
- return temp_sum;
- end;
- select add_func(1,1) from dual;
- --定义一个函数:获取给定部门的工资总和。要求:部门号定义为參数,工资总额定义为返回值;
- create function get_sal(dept_id number)
- return number
- is
- v_sumsal number(10):=0;
- cursor salary_cursor is select salary from employees where department_id = dept_id;
- begin
- for c in salary_cursor loop
- v_sumsal := v_sumsal + c.salary;
- end loop;
- return v_sumsal;
- end;
- select get_sal(60) from dual;
- --定义一个函数 获取指定部门的工资总和 和 该部门的员工总数(定义为out类型的參数)
- --要求部门号定义为參数,工资总额定义为返回值
- create function get_sall(dept_id number , total_count out number)
- return number
- is
- v_sumsal number(10):=0;
- cursor salary_cursor is select salary from employees where department_id = dept_id;
- begin
- total_count := 0;
- for c in salary_cursor loop
- v_sumsal := v_sumsal + c.salary;
- total_count := total_count + 1;
- end loop;
- return v_sumsal;
- end;
- 4:函数的调用
- declare
- v_num number(5):=0;
- begin
- dbms_output.put_line(get_sall(60,v_num));
- dbms_output.put_line(v_num);
- end;
ORACLE 存储函数的更多相关文章
- Oracle存储函数,存储过程
一.Oracle存储函数:存储的PL/SQL语法块,完成特定的功能.1.语法: 函数关键字: function (1)创建函数 CREATE [OR REPLACE] FUNCTION <fun ...
- Oracle存储函数jdbc调用
package com.jckb.procedure; import java.sql.CallableStatement; import java.sql.Connection; import ja ...
- oracle存储函数实例
CREATE OR REPLACE PROCEDURE "PROC_INS_DAY_DOCTOR_LL"(v_date in VARCHAR) is --PROC_INS_DAY_ ...
- oracle 存储函数,更新库存
create procedure PRO_update_Goods_group_stock is v_min_stock , ); v_gg_stock , ); v_goods_no number; ...
- Oracle的基本语法,存储函数及触发器
1.PL/SQL PL/SQL是Oracle对 ql语言的过程化扩展,指在 SQL 命令语言中增加了过程处理语句,使SQL语言具有过程处理能力.把 SQL 语言的数据操纵能 力与过程语言的数据 ...
- Oracle03——游标、异常、存储过程、存储函数、触发器和Java代码访问Oracle对象
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7476717.html 1.游标(光标)Cursor 在写java程序中有集合的概念,那么 ...
- oracle存储过程和存储函数&触发器
oracle存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程,存储函数 存储过程和存储函数的相同点:完成特定功能的程序 存储过程和存储函数的区别:是否用return语句返回值 ...
- oracle之存储过程和存储函数的使用和区别
#存储过程:封装在服务器上一段sql片段,已经编译好了的代码. 1.客户端调存储过程,执行效率就会非常高效. 语法: create [or replace] procedure 存储过程名称 (参数名 ...
- Java代码调用Oracle的存储过程,存储函数和包
Java代码调用存储过程和存储函数要使用CallableStatement接口 查看API文档: 上代码: java代码调用如下的存储过程和函数: 查询某个员工的姓名 月薪 职位 create or ...
随机推荐
- Get与Post方法的区别
Http协议定义了很多与服务器交互的方法,最基本的有4种,分别是GET,POST,PUT,DELETE. 一个URL地址用于描述一个网络上的资源,而HTTP中的GET, POST, PUT, DELE ...
- 大家的备忘录——xpage_在同一页面展开文档显示该文档详细信息(可显示处理过的Rich Text)
Xpage大纲: 解析: 1.通过[link2]点击触发jQuery事件来展开[面板:thispanel] 2.[面板:thispanel]写了onClientLoad事件:让thispanel隐藏. ...
- POJ 1195 Mobile phones【二维树状数组】
<题目链接> 题目大意: 一个由数字构成的大矩阵,开始是全0,能进行两种操作1) 对矩阵里的某个数加上一个整数(可正可负)2) 查询某个子矩阵里所有数字的和要求对每次查询,输出结果 解题分 ...
- sudo passwd root输入普通用户密码后显示用户不再sudoers文件中
在写上一篇VirtualBox创建共享文件夹的时候,在运行下图授权时,root密码一直输入错误 然后我就在终端输入 su root,却发现需要密码,但我却不知道密码是什么 于是我就在终端输入如下命令, ...
- SpringBoot的第一个web项目
这一节主要是讲springboot搭建简单的web项目. 首先pom文件新增spring-boot-starter-web依赖,pom文件如下所示 <?xml version="1.0 ...
- 如何调用wasm文件?
如果用C/C++导出wasm模块,方法名会默认带_前缀:如果是asm.js转成了wasm模块,方法名就不带_前缀. 一.c到js 二.wasm和js 三.小尝试 这里主要汇集了自己初学webAssem ...
- jmeter时间格式化
jmeter时间格式化 #17位时间取到毫秒 ${__time(yyyyMMdd-HHmmssSSS,)} #10位时间戳 ${__time(/1000,)} yyyyMMddHHmmss yyyy年 ...
- Redis自学笔记:4.2进阶-过期时间
4.2过期时间 **4.2.1命令介绍* 在redis中使用 expire 命令设置一个键的过期时间后redis会自动删除它. expire key seconds (seconds单位是秒,必须是整 ...
- Android多线程的使用
The speed and efficiency of a long-running, data-intensive operation often improves when you split i ...
- maven命令注册jar包到maven仓库
首先需要具备maven环境 在cmd命令行执行以下命令注册jar包 mvn install:install-file -Dfile=E:\aliyun-java-sdk-dysmsapi-1.0.0. ...