oracle自定义函数

--=============================

--author:yeeXun

--date:发表于 @2010年12月25日 10:54:00

--address:Jau 17-304

--==============================

Oracle函数,分为系统函数和自定义函数,这里介绍自定义函数。

函数用于返回特定数据,可以返回一个或多个值。在一个函数中必须包含一个或多个RETURN 语句,函数调用是PL/SQL表达式的一部分,而过程调用可以是一个独立的PL/SQL语句。

 

创建自定义函数的语法如下:

Create  [or  replace ]  function 函数名

[(参数[{in | out | in  out}]  数据类型 ,...... )]

Return  返回类型

[authid {current_user | designer}]

{is | as}

Begin

函数体

End  函数名;

 

Or  replace:如果要创建的函数存在,则先删除此函数,再重建此函数,也就是将撤销和重建这两个步骤合为一步操作。

In | out | in out:参数的模式。

authid curren_user :在调用时, oracle 使用调用该过程的用户权限域执行该过程,此时调用者必须有权限访问存储过程中所涉及到的所有数据库对象的权限。

authid designer :为默认选线, oracle 将使用过程所有者的权限来执行.

 

下面是一个例子:


SQL> create function leap_or_common_year

  2  (year in integer)

  3  return varchar2 is

  4  retval varchar2(30);

  5  begin

  6         if (year mod 400)=0 or ( (year mod 100)!=0 and (year mod  4)=0 ) then

  7         retval:=year||' is a leap year;';

  8         else

  9         retval:=year||' is a common year;';

  10         end if;

  11  return retval;

  12  end leap_or_common_year;


接下来我们调用这个函数:


SQL> select leap_or_common_year(2010) from dual;

LEAP_OR_COMMON_YEAR(2010)

--------------------------------------------------------------------------------

2010 is a common year;

 

 

SQL> select leap_or_common_year(2012) from dual;

LEAP_OR_COMMON_YEAR(2012)

--------------------------------------------------------------------------------

2012 is a leap year;

 

 

函数的删除:

Drop  function  函数名;

例如:

SQL> drop function leap_or_common_year;

Function dropped

 

--the end--

### Oracle 数据库自定义函数的创建与使用 在 Oracle 数据库中,自定义函数是一种非常强大的工具,可以用来封装逻辑、提高代码复用性以及解决跨数据库兼容性问题。以下是关于如何创建和使用自定义函数的详细说明。 #### 创建存储函数 创建存储函数的基本语法如下: ```sql CREATE [OR REPLACE] FUNCTION 函数名 (参数列表) RETURN 函数值类型 AS -- 定义局部变量 BEGIN -- 函数体逻辑 RETURN 返回值; END; ``` - `CREATE OR REPLACE`:如果函数已经存在,则替换它。 - 参数列表:可以包含零个或多个参数,每个参数都有名称、模式(IN、OUT 或 IN OUT)和数据类型。 - `RETURN`:指定函数返回的数据类型。 #### 示例 1:无参函数 以下是一个简单的无参函数示例,用于返回当前日期[^3]: ```sql CREATE OR REPLACE FUNCTION get_current_date RETURN DATE AS BEGIN RETURN SYSDATE; END; ``` 调用该函数的方式如下: ```sql SELECT get_current_date FROM DUAL; ``` #### 示例 2:带参函数 以下是一个带参函数示例,用于统计某个部门的员工人数[^4]: ```sql CREATE OR REPLACE FUNCTION depA2(dep VARCHAR2) RETURN NUMBER AS result NUMBER; BEGIN SELECT COUNT(e.deptno) INTO result FROM SCOTT.dept d LEFT JOIN SCOTT.emp e ON d.deptno = e.deptno WHERE d.dname = dep; RETURN result; END; ``` 调用该函数时,可以传递部门名称作为参数: ```sql SELECT depA2('SALES') FROM DUAL; ``` #### 示例 3:外部函数 Oracle 支持通过外部函数调用 C/C++ 编写的动态链接库。例如,假设有一个名为 `mylib.so` 的动态链接库,其中包含一个函数 `add_numbers`,可以通过以下方式注册并调用它[^2]: ```sql CREATE LIBRARY mylib AS '/path/to/mylib.so'; CREATE OR REPLACE FUNCTION add_numbers(a NUMBER, b NUMBER) RETURN NUMBER AS EXTERNAL NAME 'add_numbers' LIBRARY mylib LANGUAGE C PARAMETERS (a BY VALUE, b BY VALUE); ``` 调用此函数的方式如下: ```sql SELECT add_numbers(5, 3) FROM DUAL; ``` #### 注意事项 - 自定义函数必须包含 `RETURN` 子句,用于返回函数值[^3]。 - 如果函数需要处理复杂逻辑,可以结合 PL/SQL 块实现。 - 在编写函数时,应考虑性能优化,避免不必要的查询或循环操作。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值