核心提示:函数用于返回特定数据。执行时得找一个变量接收函数的返回值; 语法如下: create or

replace function function_name ( argu1 [mode1] datatype1, argu2

[mode2] datatype2, ........ ) return datatype is begin end; 执行 var

v1 varchar2(100) exec :v1:=function_na

-

函数用于返回特定数据。执行时得找一个变量接收函数的返回值;

语法如下: create or replace function function_name

(

argu1 [mode1] datatype1,

argu2 [mode2] datatype2, ........

)

return datatype

is

begin

end;

执行 var v1 varchar2(100)

exec :v1:=function_name

不带任何参数

create or replace function get_user return varchar2 is

Result varchar2(50);

begin

select username into Result from user_users;

return(Result);

end get_user;

执行:

带in参数的

create or replace function get_sal(empname in varchar2) return

number is

Result number;

begin

select sal into Result from emp where ename=empname;

return(Result);

end get_sal;

执行: SQL> var sal number

SQL> exec :sal:=get_sal('scott');

带out参数的函数

create or replace function get_info(e_name varchar2,job out

varchar2) return number is

Result number;

begin

select sal,job into Result,job from emp where

ename=e_name;

return(Result);

end get_info;

执行: SQL> var job varchar2(20)

SQL> var dname varchar2(20)

SQL> exec :dname:=get_info('SCOTT',:job)

带in out参数的函数

create or replace function result(num1 number,num2 in out

number) return number is

v_result number(6);

v_remainder number;

begin

v_result :=num1/num2;

v_remainder :=mod(num1,num2);

num2 :=v_remainder;

return(v_result);

Exception

when zero_divide then

raise_application_error(-20000,'不能除0');

end result;

执行: var result1 number;

var result2 number;

exec :result2:=30

exec :result1:=result(100,:result2)

eg:

1 、一个最简单的自定义函数Fun_test1的定义。

create or replace function Fun_test1(p_1

number)--Fun_test1是函数名,有一个输入参数p_1,是number型的。返回值也是number型的

return number

IS

begin

if p_1>0 then

return 1;

elsif p_1=0 then

return 0;

else

return -1;

end if;

end;

--这个函数只是可以知道自定义函数的定义和格式。其实没什么用途。

2、Fun_test1自定义函数的调用的存储过程Pro_Fun_test1_1示例:

create or replace procedure Pro_Fun_test1_1(

p1_in in number,

p2_out out number

)

AS

begin

p2_out:=Fun_test1(p1_in);

end Pro_Fun_test1_1;

--一个输入参数,一个输出参数

3、Fun_test1自定义函数的调用的存储过程Pro_Fun_test1_2示例:

create or replace procedure Pro_Fun_test1_2(

p1_in in number,

p2_out out number

)

AS

t_1 number;

begin

select Fun_test1(p1_in)+100 INTO p2_out

from bill_org where org_ID=1;

end Pro_Fun_test1_2;

--自定义函数的调用方法和的

其它内部函数是一样的。

二、包的定义和使用入门

包一般是过程和函数的集合,对过程和函数进行更好的封装,一般不针对字段。

包的构成包括包头和包体。

1、包头的定义:

包头仅仅只是对包中的方法进行说明,而没有实现

语法:

create or replace package myPackage_1

is

procedure syaHello(vname varchar2);--申明了该包中的一个过程

end;

2、包体的定义:

包体是对包头中定义的过程、函数的具体实现。

create or replace package body myPackage_1

is

procedure syaHello(vname varchar2)--对包中定义的过程的实现

is

begin

dbms_output.put_line('Hello '||vname);

end;

end;

要注意的是:

create or replace package后面的名称必须和create or replace package

body后面的名称一致,

如果将create or replace package body后面的名称改为,'MYPACKAGE'

否则将会出现诸如下面的错误:

必须说明标识符 'MYPACKAGE'

3、调用包用的自定义方法:

create or replace procedure Pro_test_package(

p1_in string

)

AS

begin

myPackage_1.syaHello(p1_in);

end Pro_test_package;

eg2:

--没有参数的函数

create or replace function get_user return varchar2 is v_user

varchar2(50);

begin

select username into v_user from user_users;

return v_user;

return v_user;

--测试

方法一

select get_user from dual;

方法二

SQL> var v_name varchar2(50)

SQL> exec :v_name:=get_user;

--带有IN参数的函数

create or replace function get_empname(v_id in number) return

varchar2 as v_name varchar2(50);

begin

select name into v_name from employee where id = v_id;

return v_name;

exception

when no_data_found then raise_application_error(-20001,

'你输入的ID无效!');

end get_empname;

附:

函数调用限制

1、SQL语句中只能调用存储函数(服务器端),而不能调用客户端的函数

2、SQL只能调用带有输入参数,不能带有输出,输入输出函数

3、SQL不能使用PL/SQL的特有数据类型(boolean,table,record等)

4、SQL语句中调用的函数不能包含INSERT,UPDATE和DELETE语句

查看函数院源代码

oracle会将函数名及其源代码信息存放到数据字典中user_source

select text from user_source where name='GET_EMPNAME';

删除函数

drop function get_empname;

判断任务过期时间:

create or replace function GetUrgentState(m_TaskID

varchar2,

m_SendTime date,

m_flag varchar2)

return varchar2 IS

myDate date;

ExpireTime date;

strsql varchar2(200);

begin

myDate := m_SendTime;

strsql := 'select max(EXPIRETIME) from t_wf_supervise where

TASKID =''' ||

m_TaskID || '''';

execute immediate strsql

into ExpireTime;

--没有到期时间 就是正常状态

if ExpireTime is null then

if m_flag = 'String' then

return '正常';

end if;

if m_flag = 'Img' then

return 'cb_execute.gif';

end if;

end if;

--未发送任务,就是判断当前时间

if m_SendTime is null then

myDate := sysdate;

end if;

if ExpireTime < myDate then

if m_flag = 'String' then

return '超期';

end if;

if m_flag = 'Img' then

return 'cb_limit.gif';

end if;

end if;

--小于3天的任务预警

if ExpireTime - myDate < 3 then

if m_flag = 'String' then

return '预警';

end if;

if m_flag = 'Img' then

return 'cb_warning.gif';

end if;

else

if m_flag = 'String' then

return '正常';

end if;

if m_flag = 'Img' then

return 'cb_execute.gif';

end if;

end if;

end;

查询其它表数据:

create or replace function GetPreNode(m_PreTaskID varchar2)

return varchar2 IS

nodename varchar2(50);

strsql varchar2(200);

begin

if m_PreTaskID is null then

return '';

end if;

strsql := 'select max(nodename) from t_Wf_Tasklist where

TaskID =''' ||

m_PreTaskID|| '''';

execute immediate strsql

into nodename;

return nodename;

end;

格式化标题输出:

create or replace function FormatTitle(m_title varchar2,

m_length number,

m_FillChar varchar2) return varchar2 IS

begin

if lengthb(m_title) > m_length*2 then

return substr(m_title, 0,m_length) || m_FillChar;

else

return m_title;

end if;

end;

oracle自定义函数获取省份,oracle 自定义函数 方法 基本例子相关推荐

  1. oracle自定义函数获取省份,Oracle 自定义函数Function

    示例代码: CREATE OR REPLACE  FUNCTION "MY_DATABASE"."F_GET_USER_COUNT_BY_DEPART" ( D ...

  2. oracle自定义函数获取省份,oracle自定义函数查询数据字典项

    /****************************** 假设存储数据字典表名:data_dict_entry 表结构如下: create table data_dict_entry ( DIC ...

  3. php获取搜索框的函数,PHP自定义函数获取搜索引擎来源关键字的方法

    本文实例讲述了PHP自定义函数获取搜索引擎来源关键字的方法.分享给大家供大家参考,具体如下: 获取搜索引擎来源关键字的函数: function getKeywords() { // 搜索引擎关键字映射 ...

  4. 【Excel2019(二十四):宏表函数】【利用宏表函数获取信息+宏表函数常见应用】

    上一篇:[Excel2019(二十三):饼图美化与PPT图表][双坐标柱形图的补充知识+饼图美化+PPT中的图表] 文章目录 利用宏表函数获取信息 get.cell函数 计算颜色 提取公式 常用的Ty ...

  5. 自定义View获取dimen值得三个方法:getDimension,getDimensionPixelOffset和getDimensionPixelSize

    getDimension和getDimensionPixelOffset的功能类似, 都是获取某个dimen的值,但是如果单位是dp或sp,则需要将其乘以density 如果是px,则不乘.并且get ...

  6. C语言fstat函数获取文件的大小

    该博文为原创文章,未经博主同意不得转载,如同意转载请注明博文出处 本文章博客地址:https://cplusplus.blog.csdn.net/article/details/105112131 f ...

  7. 小程序 | 云函数获取用户openid

    云函数获取用户openid 云函数获取用户openid openid是用户唯一标识符,如果获取用户openid可以在程序功能实现上省去很多事情. 具体操作 微信开发者工具中WXML.JS.WXSS与网 ...

  8. 计算机函数公式的使用VLOOKUP,EXCEL函数公式大全使用VLOOKUP函数IF函数数据验证来自动获取价格...

    EXCEL函数公式大全使用VLOOKUP函数,IF函数和数据验证来通过下拉框自动获得产品价格. Excel函数和公式在工作中经常使用. 是否直接使用公式决定了我们的工作效率. 今天,我们将学习VLOO ...

  9. 【MATLAB】基本绘图 ( 句柄值 | 对象句柄值获取 | 创建对象时获取句柄值 | 函数获取句柄值 | 获取 / 设置 对象属性 | 获取对象属性 )

    文章目录 一.对象句柄值获取 1.句柄值 2.创建对象时获取句柄值 3.函数获取句柄值 4.获取 / 设置 对象属性 二.获取对象属性 1.获取 线 对象属性 2.获取 坐标轴 对象属性 一.对象句柄 ...

最新文章

  1. 容斥 + 树形dp ---- 2021 icpc 沈阳 L Perfect Matchings
  2. 影谱科技宣布完成13.6亿D轮融资 商汤软银等多家参与
  3. global 和 nonlocal关键字
  4. 知道焊缝长度如何确定节点板尺寸_管桁架加工之钢结构焊接节点处理
  5. 网页 两秒弹出窗口_电脑网页打不开但qq能用怎么回事
  6. Spring Boot 日志管理
  7. leetcode1070. 产品销售分析 III(SQL)
  8. Python入门学习笔记(3)
  9. webstorm配置scss自动编译路径
  10. Android 11 第三个开发者预览版发布,新增无线调试功能
  11. 2020年终系列:国内区块链专利授权总数不足3000项|链塔智库
  12. 如何打开.DAT格式的测风数据?
  13. WIN10华硕解决无法调节电脑亮度
  14. ValueError: Cannot assign “<...>“: the current database router prevents this relation.
  15. 2014年值得关注的10个开源项目(下)
  16. emac 64位 for windows下载
  17. 苹果7 无线流量连接不上网络连接服务器,iPhone7连不上wifi无线网的四种解决方法...
  18. pdf转html?pdf转图片
  19. Tushare学习文档(八 银行间同业拆放利率)
  20. 在线教育项目技术笔记2

热门文章

  1. 基于 abp vNext 和 .NET Core 开发博客项目 - 自定义仓储之增删改查
  2. mysql三次握手_TCP的三次握手和四次挥手详解
  3. 多线程下载的原理和基本用法
  4. C++ 输出当前所在的路径
  5. 算个欧拉函数给大家助助兴(米勒拉宾(判断素数)+Pollard_rho(求一个大数的因子 ))
  6. i7 8700 服务器系统,i7 8700k 云服务器6
  7. U-Boot 之五 详解 U-Boot 及 SPL 的启动流程
  8. USB 之三 常用抓包/协议分析工具(Bus Hound、USBlyzer、USBTrace、USB Monitor Pro等)
  9. linux / scp 详解
  10. java 取字符的ascii_如何用java获得字符串的ASCII值