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

这篇具有很好参考价值的文章主要介绍了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、以管道形式返回结果集文章来源地址https://www.toymoban.com/news/detail-707230.html

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 作为返回结果集)

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

到了这里,关于oracle 自定义函数(非常简单明了)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ORACLE数据库 开窗函数

    开窗函数 2.1开窗函数的定义及语法 开窗函数(又名:分析函数,窗口函数,OLAP函数) 聚合函数:将数据按照一定的规则分组,统一分析各组的某项情况,每个分组返回一行结果 开窗函数:将数据按照一定的规则分组,统一分析各组的某项情况,每行数据返回一行结果 (

    2024年02月11日
    浏览(50)
  • LR中监控ORACLE数据库常用计数器(如何自定义Oracle计数器)

    目录 一、添加自定义计数器的方法 1、要创建自定义查询,请执行以下操作: 2、配置文件示例对象 二、常用自定义计数器列表 三、LR中监控ORACLE数据库常用计数器遇到问题及处理 1. 在安装路径的Mercury LoadRunnerdatmonitors找到vmon.cfg文件,打开。 2. 在vmon.cfg文件的第三行中,

    2024年02月15日
    浏览(53)
  • Oracle、达梦:☆获取数据库对象、获取对象的DDL定义语句(达梦)

    以下方式在达梦DM数据库中都能跑通,Oracle未测试所有的方式。 数据库所有对象表:包括 表、视图、物化视图、函数、存储过程……等 ①、ALL_OBJECTS视图方式 OBJECT_TYPE 解释: oracle 的ALL_OBJECTS中的OBJECT_TYPE表示: TABLE :表示表,这是用于存储和管理数据库中数据的主要结构。

    2024年02月03日
    浏览(83)
  • Python从Oracle数据库中获取数据——fetchall(),fetchone(),fetchmany()函数功能分析

    Python从Oracle数据库中获取数据——fetchall(),fetchone(),fetchmany()函数功能分析 1、fetchall()函数,它的返回值是多个元组,即返回多个行记录,如果没有结果,返回的是() 2、fetchone()函数,它的返回值是单个的元组,也就是一行记录,如果没有结果,那就会返回None,每次向后抓取一条记录 3、

    2024年02月15日
    浏览(52)
  • 数据库SQL函数 根据身份证号/出生年月 精确计算年龄(Oracle/MySQL)

    问题 根据身份证号统计年龄(18位) Oracle 思路 (1)Substr()函数在Oracle使用中表示被劫取的字符串表达式,截取字符串的内容。 (2)To_date()函数可以转换不同格式的日期,通过使用to_date函数可以将字符串类型的日期转换成date格式。 (3)Months_between()函数反悔两个日期之间的

    2024年02月11日
    浏览(50)
  • WIndows 配置多版本python环境,非常清晰明了

    配置多个python环境 下面以配置三个python版本环境为例子 首先下载好三个环境的python,如: python2.7、python3.6、python3.10 给个官网链接自己下,想要几版本就下几:https://www.python.org/downloads/windows/ 下载完成后将python2.7中的python.exe文件改名为python2.exe,也可以叫python2.7.exe, 反正叫

    2024年02月10日
    浏览(42)
  • 什么是数据库中的函数(库函数与自定义函数)

    目录 数据库的库函数 一、聚合函数: 1、count: 二、日期时间函数: 1:now: 2:data 3:time 4:date_format 三、常用的库函数 1:upper 2:lower 3:substring 4:round 5:length 6:concat 7:database 8:user 9:power 四、其他函数: 自定义函数的创建: 自定义函数function 1、 函数创建 2、函数调用 3、自定义

    2024年02月02日
    浏览(68)
  • PHP最简单自定义自己的框架数据库封装调用(五)

    1、实现效果调用实现数据增删改查封装   2、创建数据表    3、index.php 入口定义数据库账号密码 4、KJ.php引入基类 5、基类使用pdo封装增删改查 ModelBase.php 6、indexCrl.php控制器调用 7、完整KJ.php代码

    2024年02月13日
    浏览(42)
  • C++ lambda表达式函数递归调用简单写法实现

    在C++11中,lambda表达式函数递归往往会带上 functional 头文件。书写形式如下: 还有相对简单点的第二种写法(C++14): 对于第二种, auto fib 的作用是为了在 lambda 表达式内部能够递归调用自身。在 C++14 中,lambda 表达式默认是无法直接递归调用的,因为在 lambda 内部无法访问到

    2024年02月15日
    浏览(51)
  • 3.6.3数据库系统-模式分解:是否保持函数依赖、保持函数依赖分解定义、无损分解、表格法、公式法

    函数依赖是通过某一个维度可以函数决定另一个部分,这里在关系模式中函数依赖一定是存在于属性之间的,只要属性在,函数依赖就存在与属性之间,在考虑模式分解的过程中,分解前有一个关系模式, 比如属性集如下: 学生(学号,姓名,系号,系名,系位置) 分解前

    2024年02月08日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包