oracle自定义函数(oracle 函数定义)

本篇文章给大家谈谈oracle自定义函数,以及oracle 函数定义对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

如何调用ORACLE自定义函数?

方式一:

CALL PAMF05_FUN(你需液庆要传入的参基脊数');

方式二:

begin

PAMF05_FUN(你需要传搏埋渗入的参数');

end;

判断一个数据是否存在于一个表中,怎么在Oracle中写自定义函数?

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

语法如扮饥下: 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_10 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;

--自定义函数的调用方法和Oracle的其它内部函数是一样的。

二、包的定义和使用入门

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

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

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中怎么调用包中声明的自定义函数

sqlplus环境下:

exec 包名.自唯则定义函数名(参数1,参数段谨2,参数N) ;

你自定义的函数,注意要在package body 里定义好,也需要在package中指燃棚声明。

在Oracle中如何调用自定义的函数

FUNC_GET_PY(),FUNC_GET_WB()是我自定绝戚义的两个获取参数拼音码和拦蠢五笔码的数据库function,使用的时候就如下简宏陪直接调用

update PLUS_OPERATOR p set (p.PY_CODE,p.WB_CODE)=

(select FUNC_GET_PY(c.OPER_NAME),FUNC_GET_WB(c.OPER_NAME) from CODE_OPERATOR c where c.OPER_CODE= p.OPER_CODE and c.OPER_CODE !='00')

[img]

关于oracle自定义函数和oracle 函数定义的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

相关阅读

  • mssqlserver(mssqlserver怎么安装)

    mssqlserver(mssqlserver怎么安装)

    简介:MSSQL Server是由微软公司开发的一种关系型数据库管理系统,是在Windows操作系统上运行的数据库服务器。它旨在提供可靠性、高性能和安全性,被广泛应用于企业级应用程序和网站开发中。多级标题:一、MSSQL Server的特点...

    2024.04.22 22:38:00作者:intanet.cnTags:mssqlserver
  • js转json(js转json在线)

    js转json(js转json在线)

    **简介**在IT技术领域中,JavaScript(简称JS)是一种常用的脚本语言,用于网页开发和编程。JSON(JavaScript Object Notation)则是一种轻量级的数据交换格式,常用于存储和传输数据。本文将讨论如何将Ja...

    2024.04.22 22:23:30作者:intanet.cnTags:js转json
  • 数据库有那些(数据库有哪些索引)

    数据库有那些(数据库有哪些索引)

    一、简介数据库是计算机中用于存储和管理数据的系统,是信息系统中最重要的组成部分之一。数据库技术在信息化时代发挥着重要作用,广泛应用于各行各业。数据库的种类有很多,每种都有其特点和适用场景。下面将介绍一些常见的数据库类型。二、关系数据库1....

    2024.04.22 22:14:00作者:intanet.cnTags:数据库有那些
  • 关于sparksqlsplit的信息

    关于sparksqlsplit的信息

    简介:作为一种基于内存的分布式数据处理框架,Spark SQL使得数据分析更加高效和灵活。而在Spark SQL中,split函数是非常常用的函数,用于将字符串通过指定的分隔符进行拆分。本文将详细介绍sparksqlsplit函数的用法和示...

    2024.04.22 22:13:30作者:intanet.cnTags:sparksqlsplit
  • 数据的处理方法(实验数据的处理方法)

    数据的处理方法(实验数据的处理方法)

    在当今数字化时代,数据处理变得越发重要。从企业管理到科研领域,人们需要处理大量的数据以获取有价值的信息。本文将介绍一些常见的数据处理方法,帮助读者更好地理解和应用数据处理技术。# 传统数据处理方法传统数据处理方法主要包括数据录入、数据清洗、...

    2024.04.22 22:09:30作者:intanet.cnTags:数据的处理方法
  • mongodb和hbase(mongodb和hbase性能)

    mongodb和hbase(mongodb和hbase性能)

    MongoDB和HBase是两种流行的NoSQL数据库系统,它们在处理大规模数据和高并发访问方面都有很好的表现。本文将对MongoDB和HBase进行比较和分析,以帮助读者了解它们各自的优缺点和适用场景。# 一、MongoDB介绍Mongo...

    2024.04.22 22:00:00作者:intanet.cnTags:mongodb和hbase
  • mysql转sqlserver(MySQL转sqlserver数据库)

    mysql转sqlserver(MySQL转sqlserver数据库)

    **简介**将MySQL数据库转移到SQL Server数据库是常见的需求,因为有时候企业需要更稳定、更强大的数据库管理系统来满足数据需求。在本文中,我们将详细讨论如何将MySQL数据库成功转移到SQL Server数据库。**准备工作**...

    2024.04.22 21:45:30作者:intanet.cnTags:mysql转sqlserver
  • 数据库的建立(数据库的建立与维护实验心得)

    数据库的建立(数据库的建立与维护实验心得)

    标题:数据库的建立简介:数据库是指在计算机系统中,用于存储和管理数据的系统。在IT技术领域,数据库起着至关重要的作用,它可以帮助我们更好地组织和管理数据,提高数据的访问效率和安全性。下面将详细介绍数据库的建立过程和相关知识。一、数据库类型1...

    2024.04.22 21:30:00作者:intanet.cnTags:数据库的建立