Oracle 函数 Function
定义
函数用于计算和返回一个结果值,把经常需要进行的计算写成函数,函数的调用是表达式的一部分。
函数与过程在创建的形式上有些相似,也是编译后放在内存中供用户使用。
函数必须有一个返回值,而过程没有做强制的规定。
RETURN在声明部分需要定义一个返回参数的类型,而在函数体中必须有一个RETURN语句。如果函数结束时还没有遇到返回语句,就会发生错误。
创建
create or replace function Fn_First
return varchar2 --不需要长度
is
Result varchar2(100); --declare,长度定义。
begin
NULL;
return(Result);
end Fn_First;
调用方法一
declare
var_str varchar(100);
begin
var_str := fn_first();
dbms_output.put_line(var_str);
调用方法二
select fn_first() from dual;
项目应用
带输入参数
CREATE OR REPLACE FUNCTION SF_PUB_STRMINUSINT
(p_beg in varchar2,
p_end in varchar2
)
return int
/**
AUTH
FUNC 两个随机号相减得数
**/
AS
v_ret int;
vs_geb varchar2(30);
vs_str varchar2(30);
vn_beg int;
vs_dne varchar2(30);
vn_end int;
begin
--反转
select reverse(p_beg) into vs_geb from dual;
--正则
select regexp_substr(vs_geb,'[0-9]+',1,1) into vs_str from dual;
--取得随机码
select to_number(reverse(vs_str)) into vn_beg from dual;
--止号
select reverse(p_end) into vs_dne from dual;
--正则
select regexp_substr(vs_dne,'[0-9]+',1,1) into vs_str from dual;
--取得随机码
select to_number(reverse(vs_str)) into vn_end from dual;
v_ret:=vn_end-vn_beg+1;
return v_ret;
end SF_PUB_STRMINUSINT;
以对象返回数据列表
create or replace function fn_test
( pid in number
)
return
tabTEST
is
Result tabTEST =tabTEST();
USERID number(12);
VNAME varchar(200);
orgid number(12);
type tab is table of number;
tab_test1 tab;
/***
create or replace type ctest as object
(
cUser number(12), --不可注释
cName varchar(200),
cOrg number(12)
)
create or replace type tabTEST is table of ctest
测试
select from table(cast(fn_test({0})as tabTEST))
***/
begin
select ID bulk collect into tab_test1 from tuser where id=pid;
Result =tabTEST();
for i in 1..tab_test1.count loop
select ID,name,belongorg into USERID,VNAME,orgid from tuser where ID=tab_test1(i); Result.extend;
Result(Result.count)=ctest(NULL,NULL,NULL);
Result(Result.count).cUser=USERID;
Result(Result.count).cName=VNAME;
Result(Result.count).cOrg =orgid;
end loop;
return(Result);
end fn_test;
Oracle 函数 Function的更多相关文章
- Oracle 函数function之返回结果集
工作中常需要经过一段复杂逻辑处理后,得出的一个结果集.并能够将这个结果集作为一个表看待,去进行关联查询 我一般采用建立函数function的方式来处理. --创建包,声明function和typeCR ...
- Oracle函数function
--function /* 函数是有返回值.-只能有一个返回值. 语法 Create or replace func1(参数) Return varchar2 As Pl/sql块 Return 'J ...
- 浅谈Oracle函数返回Table集合
在调用Oracle函数时为了让PL/SQL 函数返回数据的多个行,必须通过返回一个 REF CURSOR 或一个数据集合来完成.REF CURSOR 的这种情况局限于可以从查询中选择的数据,而整个集合 ...
- oracle的function和procedure返回值给shell
本文演示两个关于如何在shell中调用oracle的function和procedure,并将返回值返回给shell. 1.首在package中创建function和procedure,脚本如下: G ...
- 汉字转拼音的Oracle函数
前言: 最近处理一个特殊的问题,需要用到汉字自动转换拼音的功能. 解决: 在这里找了不少资料,都是有所缺陷,而且也好像很绕.其实是一个很简单的东东.后来还是自己写了一个函数获取.分享出来,给有需要的X ...
- oracle 函数中,一定要注意出现空记录和多条记录的处理方法
今天折腾了3个小时,为一个以前不知道的oracle函数机制: 在sql查询中,如果一个查询未能获取记录,oracle不会报错 如select aa from bb where 1=2; 但在oracl ...
- Oracle Table Function
Oracle Table Function在Oracle9i时引入.完美的兼容了view和存储过程的长处: 应用举例: 1.Table()函数: set feedback off create or ...
- 【函数】Oracle函数系列(1)--字符函数
[函数]Oracle函数系列(1)--字符函数 1 BLOG文档结构图 2 前言部分 2.1 导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识 ...
- Jpa-Spec oracle函数bitand,instr等扩展
jpa-spec github: https://github.com/wenhao/jpa-spec 使用这个框架可以简化我们拼条件的复杂度,如下代码: public Page<Person& ...
随机推荐
- 一个简单的go语言爬虫
package main import ( "bufio" "fmt" "golang.org/x/net/html/charset" &q ...
- 【easy】479. Largest Palindrome Product
Find the largest palindrome made from the product of two n-digit numbers Since the result could be v ...
- nginx,作为前端的你会多少?
--现在阅读的你,如果是个FE,相信你不是个纯切图仔.反之,如果是,该进阶了,老铁! 前端的我们,已经不仅仅是做页面,写样式了,我们还需要会做相关的服务器部署.废话不多说,下面就从前端的角度来讲以下n ...
- nginx的location配置详解
语法规则: location [=|~|~*|^~] /uri/ { … } =开头表示精确匹配 ^~开头表示uri以某个常规字符串开头,理解为匹配url路径即可.nginx不对url做编码,因此请求 ...
- LoadRunner监控数据库服务
一.LR监控SQL Server SQL Server自身提供的性能计数器指标有: 指标名称 指标描述 指标范围 指标单位 1.SQL Server中访问方法(Access Methods)对象包含的 ...
- docker bulid命令
使用当前目录的 Dockerfile 创建镜像,标签为 runoob/ubuntu:v1. docker build -t runoob/ubuntu:v1 . 使用URL github.com/cr ...
- 01-初识MySQL数据库
一.数据库概述 1.什么是数据 描述事物特征的符号记录称为数据,描述事物的符号既可以是数字,也可以是文字.图片,图像.声音.语言等,数据由多种表现形式,它们都可以经过数字化后存入计算机.如: name ...
- C++中的const总结
CONST 一.符号常量 声明: const 类型说明符 常量名 = 常量值: const float PI = 3.1415927; //可以交换const与float的位置 符号常量在声明时一定要 ...
- 初探storm
Storm入门之Storm示例及UI参数讲解 Storm UI REST API Storm 1.1.0 中文文档 Apache Storm 1.1.0 中文文档 | ApacheCN Storm U ...
- Redis数据类型SortedSET
Sorted Set有点像Set和Hash的结合体.和Set一样,它里面的元素是唯一的,类型是String,所以它可以理解为就是一个Set.但是Set里面的元素是无序的,而Sorted Set里面的元 ...