oracle函数返回一个变量包含多个属性
来源:互联网 发布:学数据库需要什么基础 编辑:程序博客网 时间:2024/05/28 23:23
Oracle中函数/过程返回结果集的3种方式,现总结如下:
以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过.
(1) 返回游标:
return的类型为:SYS_REFCURSOR
之后在IS里面定义变量:curr SYS_REFCURSOR;
最后在函数体中写:
open cur for
select ......;
return cur;
例:
(2)返回table类型的结果集:
首先定义一个行类型:
其次以此行类型定义一个表类型:
定义函数(此函数完成字符串拆分功能):
在PL/SQL developer中可以直接调用
(3)以管道形式输出:
以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过.
(1) 返回游标:
return的类型为:SYS_REFCURSOR
之后在IS里面定义变量:curr SYS_REFCURSOR;
最后在函数体中写:
open cur for
select ......;
return cur;
例:
CREATEORREPLACEFUNCTION A_Test(
orTypevarchar2
)RETURN SYS_REFCURSOR
is
type_cur SYS_REFCURSOR;
BEGIN
OPEN type_curFOR
select col1,col2,col3from testTable ;
RETURN type_cur;
END;
orTypevarchar2
)RETURN SYS_REFCURSOR
is
type_cur SYS_REFCURSOR;
BEGIN
OPEN type_curFOR
select col1,col2,col3from testTable ;
RETURN type_cur;
END;
(2)返回table类型的结果集:
首先定义一个行类型:
CREATEORREPLACE TYPE "SPLIT_ARR" AS OBJECT(nowStrvarchar2(18))
其次以此行类型定义一个表类型:
CREATEOR REPLACE TYPE "SPLIT_TAB"ASTABLEof split_arr;
定义函数(此函数完成字符串拆分功能):
CREATEORREPLACEFUNCTION GetSubStr(
strinvarchar2,--待分割的字符串
splitcharinvarchar2--分割标志
)
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;
endif;
if indexStr= 1then---第一个字符便为分隔符,此时去掉分隔符
begin
restStr := substr(restStr,2);
goto top;
end;
endif;
if length(restStr)=0or restStris nullthen
return v;
endif;
v.extend;
thisStr := substr(restStr,1,indexStr-1);--取得当前的字符串
restStr := substr(restStr,indexStr+1);---取剩余的字符串
v(v.count) := split_arr(thisStr);
END LOOP;
return v;
end;
strinvarchar2,--待分割的字符串
splitcharinvarchar2--分割标志
)
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;
endif;
if indexStr= 1then---第一个字符便为分隔符,此时去掉分隔符
begin
restStr := substr(restStr,2);
goto top;
end;
endif;
if length(restStr)=0or restStris nullthen
return v;
endif;
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 nowStrfromTable(GetSubStr('111,222,333,,,',','));
select nowStrfromTable(GetSubStr('111,222,333,,,',','));
(3)以管道形式输出:
create type row_typeas object(a varchar2(10), vvarchar2(10));--定义行对象
create type table_typeastableof row_type;--定义表对象
createor replacefunction test_fun(
ainvarchar2,binvarchar2
)
return table_type pipelined
is
v row_type;--定义v为行对象类型
begin
for thisrowin (select a, bfrom mytablewhere 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'));
create type table_typeastableof row_type;--定义表对象
createor replacefunction test_fun(
ainvarchar2,binvarchar2
)
return table_type pipelined
is
v row_type;--定义v为行对象类型
begin
for thisrowin (select a, bfrom mytablewhere 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'));
0 0
- oracle函数返回一个变量包含多个属性
- c#函数返回多个变量
- C++函数返回多个变量
- 字符串包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数
- 调用一个函数返回多个结果
- 一个函数如何返回多个参数
- 写一个字符串函数,这个字符串参数必须包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数。
- 字符串包含一个或多个数字,编写函数把数字字符转化为整数并返回这个整数。如果字符串包含任何非数字字符,函数就返回零。
- 这个字符串参数必须包含一个或多个数字,函数应该把这些 数字字符转换为整数并返回这个整数。如果字符串参数包含 了任何非数字字符,函数就返回零。
- 字符串参数必须包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数。如果字符串参数包含了任何非数字字符,函数就返回零
- C 这个字符串参数必须包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数。如果字符串参数包含了任何非数字字符,函数就返回零。
- int ascii_to_integer(char *str); 这个字符串参数必须包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数。
- C#中如何让一个函数返回多个
- 分解一个枚举类型变量包含的多个枚举值
- thinkphp模板输出变量使用一个或多个函数
- Enum扩展,可以包含多个属性
- 函数多个返回值(返回多个参数/局部变量)通过双重指针来实现
- 【c语言】为下面的函数原型编写函数定义,这个字符串参数必须包含一个或者多个数字,函数应该把这些数字字符转换为整数并返回这个整数。
- 对于CocoaPods的简单理解,实践安装使用过程和常见问题
- postgresql 主备机的判断
- Java异常处理(3)自动关闭的try
- 关于网络请求的学习理解
- java设计模式—单例模式
- oracle函数返回一个变量包含多个属性
- python中#!/usr/bin/python与#!/usr/bin/env python的区别
- Android蓝牙4.0API内容-接口-BluetoothProfile
- JS 四舍五入
- 服务器端select I/O多路复用模型
- NYOJ 35 表达式求值(栈)
- 手把手教您扩展SWAP虚拟内存
- MOOC平台
- Android:打开相册(动态布局,Activity以dialog方式显示,图片压缩)