日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle返回表id,在Oracle的函数中,返回表类型的语句

發布時間:2025/4/16 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle返回表id,在Oracle的函数中,返回表类型的语句 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Oracle的function中怎么返回表變量?

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

1、創建表對象類型。

在Oracle中想要返回表對象,必須自定義一個表類型,如下所示:

復制代碼 代碼如下:

create or replace type t_table is table of number;

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

定義對象類型:

復制代碼 代碼如下:

create or replace type obj_table as object

(

id int,

name varchar2(50)

)

修改表對象類型的定義語句如下:

復制代碼 代碼如下:

create or replace type t_table is table of obj_table;

2、 創建演示函數

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

1)、管道化表函數方式:

復制代碼 代碼如下:

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表示結束.

調用函數的方式如下:

復制代碼 代碼如下:

select * from table(f_pipe(5));

2)、 普通的方式:

復制代碼 代碼如下:

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;

初始化值后還可以想注視行那樣進行修改.

調用方式如下:

復制代碼 代碼如下:

select * from table(f_normal(5));

ok 完成

免責聲明:本站所有文章和圖片均來自用戶分享和網絡收集,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系網站客服處理。

總結

以上是生活随笔為你收集整理的oracle返回表id,在Oracle的函数中,返回表类型的语句的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。