在Oracle/SQL Service中通过Function返回Table

简介: 本函数用途:返回一个Table 在Oracle中实现,范例: 1 --在Types中: 2 create or replace type objTable as object 3 ( 4 s_usercode varchar2(32767), 5 s_usernam...

本函数用途:返回一个Table

在Oracle中实现,范例:

 1 --在Types中:
 2 create or replace type objTable as object
 3 (
 4   s_usercode varchar2(32767),
 5   s_username varchar2(32767)
 6 );
 7 
 8 CREATE OR REPLACE TYPE tabTemp AS TABLE OF objtable;
 9 
10 
11 --在Function中:
12 --使用Pipeline管道函数和Pipe row()
13 create or replace function GetCSClient
14 (
15 /*
16 程式代号:GetCSClient
17 程式名称:
18 传入参数:
19 传回值:
20 备注:
21 范例:select * from table(GetCSClient('Shadowxiong'));
22 版本变更:        
23 xx.   YYYY/MM/DD   VER    AUTHOR         COMMENTS
24 01.   2015/08/28   1.00   Anne_Han       New Create              
25 */
26   P_Usercode varchar2
27 ) 
28 return tabtemp PIPELINED
29 as
30   s_usercode varchar2(32767);
31   s_username varchar2(32767);
32   v          objtable;
33 begin
34   for myrow in (select CShortName,CEnglishName from mv_liclientbaseinfo order by CShortName)
35   loop
36     v:=objtable(myrow.CShortName, myrow.CEnglishName);
37     PIPE ROW (v);
38   end loop;
39   
40   RETURN;
41     
42 end GetCSClient;

 

在SQL Service中实现,范例:

 1 --在Function中:
 2 CREATE FUNCTION [dbo].[GetCSClient] (@USER_CODE NVARCHAR(30))   
 3 RETURNS  @objTable  TABLE (ClientId nvarchar(15),CLIENTNAME nvarchar(150))
 4 AS
 5 BEGIN
 6     INSERT INTO @objTable(ClientId,CLIENTNAME)
 7     SELECT  CLIENTID,CLIENTNAME FROM CLIENT WITH(NOLOCK) 
 8     ORDER BY CLIENTID
 9  
10     RETURN
11 END
12 
13 --调用Function
14 SELECT * FROM dbo.GetCSClient('shadowxiong')

 

 

如果您看了本篇博客,觉得对您有所收获,请点击右下角的 [推荐]

如果您想转载本博客,请注明出处

如果您对本文有意见或者建议,欢迎留言

感谢您的阅读,请关注我的后续博客

目录
相关文章
|
2月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
2月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
86 3
|
2月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
76 1
|
4月前
|
SQL JavaScript 前端开发
【Azure 应用服务】Azure JS Function 异步方法中执行SQL查询后,Callback函数中日志无法输出问题
【Azure 应用服务】Azure JS Function 异步方法中执行SQL查询后,Callback函数中日志无法输出问题
|
5月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
391 3
|
5月前
|
SQL 存储 Oracle
TDengine 3.3.2.0 发布:新增 UDT 及 Oracle、SQL Server 数据接入
**TDengine 3.3.2.0 发布摘要** - 开源与企业版均强化性能,提升WebSocket、stmt模式写入与查询效率,解决死锁,增强列显示。 - taos-explorer支持geometry和varbinary类型。 - 企业版引入UDT,允许自定义数据转换。 - 新增Oracle和SQL Server数据接入。 - 数据同步优化,支持压缩,提升元数据同步速度,错误信息细化,支持表名修改。 - 扩展跨平台支持,包括麒麟、Euler、Anolis OS等。
135 0
|
1月前
|
中间件 Docker Python
【Azure Function】FTP上传了Python Function文件后,无法在门户页面加载函数的问题
通过FTP上传Python Function至Azure云后,出现函数列表无法加载的问题。经排查,发现是由于`requirements.txt`中的依赖包未被正确安装。解决方法为:在本地安装依赖包到`.python_packages/lib/site-packages`目录,再将该目录内容上传至云上的`wwwroot`目录,并重启应用。最终成功加载函数列表。
|
2月前
|
JavaScript
箭头函数与普通函数(function)的区别
箭头函数是ES6引入的新特性,与传统函数相比,它有更简洁的语法,且没有自己的this、arguments、super或new.target绑定,而是继承自外层作用域。箭头函数不适用于构造函数,不能使用new关键字调用。
|
2月前
|
数据可视化 开发者 索引
详解Wireshark LUA插件函数:function p_myproto.dissector(buffer, pinfo, tree)
在 Wireshark 中,LUA 插件通过 `function p_myproto.dissector(buffer, pinfo, tree)` 扩展协议解析能力,解析自定义应用层协议。参数 `buffer` 是 `PacketBuffer` 类型,表示原始数据包内容;`pinfo` 是 `ProtoInfo` 类型,包含数据包元信息(如 IP 地址、协议类型等);`tree` 是
95 1
|
2月前
|
JavaScript
箭头函数与普通函数(function)的区别
箭头函数是ES6引入的新语法,相比传统函数表达式更简洁,且没有自己的this、arguments、super或new.target绑定,而是继承自外层作用域。这使得箭头函数在处理回调和闭包时更加灵活方便。

热门文章

最新文章

推荐镜像

更多