佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 在Oracle的函數(shù)中,返回表類型的語句

在Oracle的函數(shù)中,返回表類型的語句

熱門標(biāo)簽:Linux服務(wù)器 地方門戶網(wǎng)站 百度競價排名 網(wǎng)站排名優(yōu)化 鐵路電話系統(tǒng) AI電銷 服務(wù)外包 呼叫中心市場需求
Oracle的function中怎么返回表變量?

太晚了,過多的理論知識就不說了,下面簡單地說實現(xiàn)吧!..

1、創(chuàng)建表對象類型。

在Oracle中想要返回表對象,必須自定義一個表類型,如下所示:
復(fù)制代碼 代碼如下:

create or replace type t_table is table of number;

上面的類型定義好后,在function使用可用返回一列的表,如果需要多列的話,需要先定義一個對象類型。然后把對象類型替換上面語句中的number;

定義對象類型:
復(fù)制代碼 代碼如下:

create or replace type obj_table as object
(
id int,
name varchar2(50)
)

修改表對象類型的定義語句如下:
復(fù)制代碼 代碼如下:

create or replace type t_table is table of obj_table;


2、 創(chuàng)建演示函數(shù)

在函數(shù)的定義中,可以使用管道化表函數(shù)和普通的方式,下面提供兩種使用方式的代碼:

1)、管道化表函數(shù)方式:
復(fù)制代碼 代碼如下:

create or replace function f_pipe(s number)
return t_table pipelined
as
v_obj_table obj_table;
begin
for i in 1..s loop
v_obj_table := obj_table(i,to_char(i*i));
pipe row(v_obj_table);
end loop;
return;
end f_pipe;

注意:管道的方式必須使用空的return表示結(jié)束.

調(diào)用函數(shù)的方式如下:
復(fù)制代碼 代碼如下:

select * from table(f_pipe(5));


2)、 普通的方式:
復(fù)制代碼 代碼如下:

create or replace function f_normal(s number)
return t_table
as
rs t_table:= t_table();
begin
for i in 1..s loop
rs.extend;
rs(rs.count) := obj_table(rs.count,'name'||to_char(rs.count));
--rs(rs.count).name := rs(rs.count).name || 'xxxx';
end loop;
return rs;
end f_normal;

初始化值后還可以想注視行那樣進(jìn)行修改.

調(diào)用方式如下:
復(fù)制代碼 代碼如下:

select * from table(f_normal(5));

ok 完成

標(biāo)簽:銅川 衡水 崇左 湖南 湘潭 黃山 蘭州 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在Oracle的函數(shù)中,返回表類型的語句》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    济阳县| 谷城县| 濮阳市| 凉山| 西盟| 青铜峡市| 夹江县| 江陵县| 渝北区| 惠东县| 开封市| 密山市| 水富县| 娄底市| 巍山| 阳城县| 龙山县| 元江| 武川县| 宜章县| 和田县| 贡山| 西畴县| 哈尔滨市| 德格县| 屯留县| 常熟市| 田东县| 嘉峪关市| 吉木乃县| 松原市| 平谷区| 西乌珠穆沁旗| 深水埗区| 长顺县| 布拖县| 宁德市| 达尔| 正定县| 扎赉特旗| 通河县|