oracle函数返回一个变量包含多个属性

Oracle中函数/过程返回结果集的3种方式,现总结如下:

以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过.

(1) 返回游标:

return的类型为:SYS_REFCURSOR

之后在IS里面定义变量:curr SYS_REFCURSOR;

最后在函数体中写:

open cur for

select ......;

return cur;

例:

CREATEOR
REPLACEFUNCTION A_Test(

                orTypevarchar2

        )RETURN SYS_REFCURSOR

       is

               type_cur SYS_REFCURSOR;

       BEGIN

           OPEN type_curFOR

                   select col1,col2,col3from
testTable ;

                 RETURN  type_cur;

       END;

(2)返回table类型的结果集:

首先定义一个行类型:

CREATEOR
REPLACE TYPE "SPLIT_ARR" AS OBJECT(nowStrvarchar2(18))

其次以此行类型定义一个表类型:

 CREATE
OR REPLACE TYPE "SPLIT_TAB"AS
TABLEof split_arr;

定义函数(此函数完成字符串拆分功能):

CREATEOR
REPLACEFUNCTION GetSubStr(

                  str
invarchar2,--待分割的字符串

                   splitcharin
varchar2--分割标志

            )

           return split_tab

           IS

              restStrvarchar2(2000)default
GetSubStr.str;--剩余的字符串

              thisStrvarchar2(18);--取得的当前字符串

              indexStrint;--临时存放分隔符在字符串中的位置

              v split_tab := split_tab();--返回结果

           begin

                 dbms_output.put_line(restStr);

                while length(restStr)!=
0

                   LOOP

                    <<top>>

                     indexStr := instr(restStr,splitchar);--从子串中取分隔符的第一个位置

                    if indexStr
= 0and length(restStr)!=
0 then--在剩余的串中找不到分隔符

                       begin

                          v.extend;

                          v(v.count) :=
split_arr(Reststr);

                         return v;

                       end;

                    end
if;

                    if indexStr
= 1then---第一个字符便为分隔符,此时去掉分隔符

                       begin

                             restStr := substr(restStr,2);

                            goto  
top;

                       end;

                    end
if;

                    if length(restStr)=
0or restStr
is nullthen

                       return v;

                    end
if;

                     v.extend;

                     thisStr := substr(restStr,1,indexStr-
1);--取得当前的字符串

                     restStr := substr(restStr,indexStr+
1);---取剩余的字符串

                     v(v.count) :=
split_arr(thisStr);

                  END LOOP;

                return v;

           end;

在PL/SQL developer中可以直接调用

cursor strcuris

                        select nowStrfrom
Table(GetSubStr(‘111,222,333,,,‘,‘,‘));

(3)以管道形式输出:

create type row_typeas
object(a varchar2(10), vvarchar2(10));--定义行对象

       create type table_typeas
tableof row_type;
--定义表对象

       create
or replacefunction test_fun(

            ain
varchar2,bin
varchar2

        )

       return table_type pipelined

       is

            v row_type;--定义v为行对象类型

       begin

         for thisrow
in (select a, bfrom mytable
where col1=aand col2
= b) loop

            v := row_type(thisrow.a, thisrow.b);

           pipe row (v);

         end loop;

         return;

       end;

       select
* fromtable(test_fun(‘123‘,‘456‘));

时间: 2024-11-15 21:49:36

oracle函数返回一个变量包含多个属性的相关文章

Entity Framework 6 Recipes 2nd Edition(11-2)译 -&gt; 为一个”模型定义”函数返回一个计算列

11-3. 为一个”模型定义”函数返回一个计算列 问题 想从”模型定义”函数里返回一个计算列 解决方案 假设我们有一个员工(Employee)实体,属性有: FirstName, LastName,和BirthDate, 如 Figure 11-3所示. Figure 11-3. An Employee entity with a few typical properties 我们想要创建一个”模型定义”函数,让它返回FirstName 和LastName 合并后的full name . 我们想

Entity Framework 6 Recipes 2nd Edition(11-5)译 -&gt; 从”模型定义”函数返回一个匿名类型

11-5. 从”模型定义”函数返回一个匿名类型 问题 想创建一个返回一个匿名类型的”模型定义”函数 解决方案 假设已有游客(Visitor) 预订(reservation)房间(hotel ) 的模型,如Figure 11-5所示. Figure 11-5. A model for hotel reservations 想要返回每位游客房间预订条数和带来的总收入.因为很多地方需要这些信息,所以想要创建一个”模型定义”函数,接受一个查询参数,返回一个包含游客合计信息的匿名类型的集合: 2. 把Li

c++函数返回一个数组

---恢复内容开始--- 调用某个函数时经常需要函数返回一个值,我们都知道c++ 的函数返回的是一个copy,所以当只返回一个值时不会出现什么问题,直接return一个copy就行了,但是如果返回一个数组,事情就变得有趣了,我最近就遇到了这个问题. 先附上代码吧: #include<iostream> using namespace std; //函数声明 int * fun1(); int * fun2(); void dispArr(int *arr ,int n); const int

浅谈Oracle函数返回Table集合

在调用Oracle函数时为了让PL/SQL 函数返回数据的多个行,必须通过返回一个 REF CURSOR 或一个数据集合来完成.REF CURSOR 的这种情况局限于可以从查询中选择的数据,而整个集合在可以返回前,必须进行具体化. 9i 通过引入Oracle函数中的管道化表函数纠正了后一种情况.表函数是返回整个行的集(通常作为一个集合)的函数,可以直接从 SQL 语句中进行查询,就好像它是一个真正的数据库表一样.管道化表函数与之相似,但是它像在构建时一样返回数据,而不是一次全部返回.管道化表函数

【转载】让c++ 函数返回一个数组

在c++中是不允许数组作为函数的返回值的 int [] someFunction( ); //ILLEGAL 要想实现函数返回一个数组,那返回对应数组里面类型的指针 you must return a pointer to the array base type and have the pointer point to the array. So, the function declaration would be as follows: int* someFunction( ); //Leg

Entity Framework 6 Recipes 2nd Edition(11-1)译 -&gt; 从“模型定义”函数返回一个标量值

第11章函数 函数提供了一个有力代码复用机制, 并且让你的代码保持简洁和易懂. 它们同样也是EF运行时能利用的数据库层代码.函数有几类: Rowset Functions, 聚合函数, Ranking Functions, 和标量值函数. 函数要么确定,要么不确定.当用一些指定的值调用函数,而函数返回的结果总是一样时,它就是确定的函数.当甚至用同样的一些值调用时,而函数每次返回的结果也可能不一样,它就是不确定的函数. 在前七小节,我们探讨“模型定义”的函数,这些函数允许我们在概念层上创建.这些函

让c++ 函数返回一个数组

让c++ 函数返回一个数组 在c++中是不允许数组作为函数的返回值的 int [] someFunction( ); //ILLEGAL 要想实现函数返回一个数组,那返回对应数组里面类型的指针 you must return a pointer to the array base type and have the pointer point to the array. So, the function declaration would be as follows:  int* someFun

array_flip() 函数返回一个反转后的数组

定义和用法 array_flip() 函数返回一个反转后的数组,如果同一值出现了多次,则最后一个键名将作为它的值,所有其他的键名都将丢失. 如果原数组中的值的数据类型不是字符串或整数,函数将报错 array_unique() 函数移除数组中的重复的值,并返回结果数组. 当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除. 返回的数组中键名不变. 在PHP中,用于删除数组中重复元素有一个可用的函数,那就是 array_unique(), 但是它并不是一个最高效的方法,使用array_fl

用python读取oracle函数返回值

在oracle中创建一个函数,本来是想返回一个index table的,没有成功.想到文本也可以传输信息,就突然来了灵感,把返回值设置文本格式. 考虑到返回数据量可能会很大,varchar2类型长度吃紧,于是将返回值类型设置为clob. 我是用scott用户的测试表,这个是函数定义情况: create or replace function test_query_func(dept varchar2) return clob is        type test_record is recor