當前位置:首頁 » 編程語言 » oracle動態sql返回值

oracle動態sql返回值

發布時間: 2024-12-06 17:11:51

⑴ 在ORACLE自定義函數里怎麼獲取一個動態sql的記錄--急

參考下這個:
declare
cursor v_tablename_cursor is
select * from v_tablename
being
for tmprow in v_tablename_cursor
loop
tmprow就是條記錄了
end loop;
end;

⑵ ORACLE FUNCTION 中如何動態執行一個未知具體列SQL後得到每行每列的數據(對每行數據的每列加分隔符拼接用)

這個需求好奇怪……

既然SQL是入參,想怎麼拼還不是傳進去的入參的問題?

按照你的例子最後的要求,想要得到'aaa分隔符bbb'的話,入參應該是「SELECT 'aaa' || '分隔符 || 'bbb' FROM al」;

另外列名也是可以從入參定義的啊。例如剛才你的列名如果想要叫ccc的話,入參改成「SELECT 'aaa' || '分隔符 || 'bbb' AS ccc FROM al」

難道還能不知道入參而調用Function么?

⑶ 如何在oracle存儲過程中執行動態sql語句

時需要在oracle 存儲過程中執行動態SQL 語句 ,例如表名是動態的,或欄位是動態的,
或查詢命令是動態的,可用下面的方法:
set serveroutput ondeclaren number;sql_stmt varchar2(50);
t varchar2(20);beginexecute immediate 'alter session set nls_date_format=''YYYYMMDD''';
t := 't_' || sysdate;
sql_stmt := 'select count(*) from ' || t;
execute immediate sql_stmt into n;
dbms_output.put_line('The number of rows of ' || t || ' is ' || n);end;
如果動態SQL 語句 很長很復雜,則可用包裝.
CREATE OR REPLACE PACKAGE test_pkgISTYPE cur_typ IS REF CURSOR;
PROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ);END;/
CREATE OR REPLACE PACKAGE BODY test_pkgISPROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ)ISsqlstr VARCHAR2(2000);BEGINsqlstr := 'SELECT * FROM '||v_table;
OPEN t_cur FOR sqlstr;END;END;/
在oracle 中批量導入,導出和刪除表名以某些字元開頭的表
spool c:\a.sql

熱點內容
如何快速清除手機圖形密碼 發布:2025-03-14 14:32:03 瀏覽:444
電子郵件賬戶的伺服器該怎麼填寫 發布:2025-03-14 14:31:59 瀏覽:421
泰拉瑞亞蒲公英怎麼開在線伺服器 發布:2025-03-14 14:21:20 瀏覽:629
如何破壞門上的密碼鎖 發布:2025-03-14 14:19:39 瀏覽:968
咖啡源碼 發布:2025-03-14 13:51:32 瀏覽:168
android漂亮的listview 發布:2025-03-14 13:40:26 瀏覽:392
android路線規劃 發布:2025-03-14 13:23:22 瀏覽:304
poi瀏覽器島風go緩存 發布:2025-03-14 13:10:24 瀏覽:189
具體可要說存儲在鋼瓶中是因為 發布:2025-03-14 13:00:36 瀏覽:442
汽車空調壓縮機不轉了 發布:2025-03-14 12:55:45 瀏覽:32