oracle自定义函数

语法:
Create [or replace] function funtionName(parameter1 mode1 dataType1,parameter2 mode2 dataType2,….) 
Return returnDataType
Is/as
--定义使用变量、返回变量
Begin
  Function_body
  Return expression
End functionName;--结束函数的声明,也可以直接写end不加函数名。
--其中mode1、mode2表示参数类型(in/out),dataType表示参数的数据类型,returnDataType表示返回值类型。
一个简单的列子,根据输入的数字,返回两个数的和:
create or replace function testAdd(js1 in number, js2 in number)
  return number is
  v_hj number;
begin
  v_hj := js1 + js2;
  return v_hj;
end;

返回一个table结果集:

-定义行类型
create or replace type v_record as object
(
 id varchar2(32),
 username varchar2(50),
 name varchar2(50)
)

--以行类型定义一个表类型
create or replace type v_table is table of v_record

--函数
create or replace function getUser(username in varchar2)
return v_table is
v_row v_record;  --定义单条数据变量
rs v_table:=v_table();  --定义返回结果并初始化
 begin
   for thisrow in(select t.id_,t.username_,t.name_ from t_sys_user t where t.username_ in ('wangying','liushaojun'))
      loop
        v_row := v_record(thisrow.id_,thisrow.username_,thisrow.name_);
        rs.extend;
        rs(rs.count):=v_row;
       end loop;
       return(rs);
   end;

函数的调用:

select testAdd(2,3) from dual;

select * from table(getUser('wangxiyun'));

 

### 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、付费专栏及课程。

余额充值