oracle 自定义函数(非常简单明了)

语法说明

复制代码
create [or replace] function functionName   (parameterName1 mode1 dataType1,  parameterName2 mode2 dataType2,  ...)  
 return returnDataType  
 is/as  
 	-- 定义使用变量、返回变量
 begin  
 	function_body  
 	return expression  
end functionName; -- 结束函数的声明,也可以直接写end不加函数名。  

-- 其中mode1、mode2表示参数类型,dataType表示参数的数据类型。returnDataType表示返回值类型。  

举例说明

1.举一个简单的例子

定义一个简单的函数,计算两数之和

复制代码
create or replace function useEasy(add1 in number, add2 in number) 
  return number 
  is
    FunctionResult number;
  begin
    FunctionResult := add1 + add2;
    return(FunctionResult);
end useEasy;

函数的使用请继续往下看

2.举一个复杂的例子(虽然复杂,但是很实用)

1⃣️、定义函数的返回类型

创建 TYPE 类型 atrr_type

复制代码
1、CREATE OR REPLACE TYPE atrr_type  AS OBJECT (
       attrId varchar2(40),
       objType varchar2(40)
);

2、将 TYPE 类型 atrr_type 定义为表, 用做接收返回值

复制代码
CREATE OR REPLACE TYPE attr_table AS TABLE of atrr_type;

2⃣️、定义函数(这里介绍三种方式)

1、以游标形式返回,有很大的局限性

复制代码
create or replace function selectAttrId(objType in VARCHAR2)
  return SYS_REFCURSOR 
  is
    attrId SYS_REFCURSOR;
  begin
    OPEN attrId FOR
      select attr_id, obj_type from CPS_OBJ_ATTR where obj_type = objType;
    return(attrId);
end selectAttrId;

2、以 Table 形式 返回结果集

复制代码
create or replace function resultFunction(objType in VARCHAR2)
  return attr_table 
  is
    attr_row 	atrr_type;        	 		  -- 定义单条数据变量
    attr     	attr_table := attr_table();   -- 定义返回结果,并初始化
  begin
    for thisrow in (select attr_id as attrId, obj_type as objType from CPS_OBJ_ATTR where obj_type = objType) 
    loop
      attr_row := atrr_type(thisrow.attrId, thisrow.objType);
      attr.extend;
      attr(attr.count) := attr_row;
    end loop;
  return(attr);
end resultFunction;

3、以管道形式返回结果集

复制代码
create or replace function returnPiperesult(objType in VARCHAR2)
  return attr_table pipelined
  is
    attr_row atrr_type;		 --定义attr_row为行对象类型
  begin
    for thisrow in (select attr_id as attrId, obj_type as objType from CPS_OBJ_ATTR where obj_type = objType)
    loop
      attr_row:= atrr_type(thisrow.attrId, thisrow.objType);
      pipe row (attr_row);
    end loop;
  return;
end returnPiperesult;

3⃣️、函数的使用

复制代码
select resultFunction('turck') from dual;			-- 直接调用函数

select * from table(resultFunction('turck'));  	-- 返回结果集table时,可以调用(自定义一个type为table 作为返回结果集)

觉得文章实用,请在右上方点个?

相关推荐
蟹至之24 分钟前
增删查改(其一) —— insert插入 与 select条件查询
数据库·mysql·增删查改
Yeats_Liao1 小时前
时序数据库系列(七):性能监控实战指标收集
数据库·后端·时序数据库
无心水1 小时前
【中间件:Redis】1、Redis面试核心:线程模型深度解析(6.0前后变化+工作流程)
数据库·redis·面试·redis面试·redis原理·redis线程模型·后端技术
milanyangbo1 小时前
从同步耦合到异步解耦:消息中间件如何重塑系统间的通信范式?
java·数据库·后端·缓存·中间件·架构
绛洞花主敏明2 小时前
Gorm(十四)的多条件叠加
数据库
枫叶丹42 小时前
【Qt开发】布局管理器(五)-> QSpacerItem 控件
开发语言·数据库·c++·qt
伯恩bourne2 小时前
【SqlServer】日志文件无法收缩的解决方法
数据库·oracle·sqlserver
像风一样自由20203 小时前
Redis与MinIO:两大存储利器的区别与联系
数据库·redis·缓存·minio
todoitbo3 小时前
使用n8n搭建服务器监控系统:从Webhook到Telegram告警的完整实现
运维·服务器·数据库·ai·向量数据库·流处理·n8n
only-code3 小时前
MCP驱动的Rgentic RRG(向量数据库+网络搜索)
数据库·python·大模型·函数调用·mcp