在遠端和本地儲存過程間傳遞陣列
簡單描述一下在遠端儲存過程和本地儲存過程之間傳遞陣列的方法。
對於本地的儲存過程直接,直接傳遞陣列是很容易的:
SQL> CREATE OR REPLACE PACKAGE PA_TEST AS
2 TYPE T_NAME IS TABLE OF VARCHAR2(30);
3 END;
4 /
程式包已建立。
SQL> CREATE OR REPLACE PROCEDURE P_TEST (P_NAME OUT PA_TEST.T_NAME) AS
2 BEGIN
3 SELECT TABLE_NAME BULK COLLECT INTO P_NAME FROM USER_TABLES;
4 END;
5 /
過程已建立。
SQL> SET SERVEROUT ON SIZE 1000000
SQL> DECLARE
2 V_NAME PA_TEST.T_NAME;
3 BEGIN
4 P_TEST(V_NAME);
5 FOR I IN 1..V_NAME.COUNT LOOP
6 DBMS_OUTPUT.PUT_LINE(V_NAME(I));
7 END LOOP;
8 END;
9 /
T_BLOB
T
T_PK
MLOG$_T
MLOG$_T_BLOB
MLOG$_T_PK
T2
RUPD$_T_PK
PL/SQL 過程已成功完成。
不過同樣的方法並不適應於遠端儲存過程呼叫:
SQL> SELECT * FROM GLOBAL_NAME;
GLOBAL_NAME
------------------------------------------------
YTK102.YTK_THINKPAD
SQL> CONN YANGTK/YANGTK@TEST1已連線。
SQL> CREATE DATABASE LINK YTK102.YTK_THINKPAD CONNECT TO YANGTK IDENTIFIED BY YANGTK USING 'YTK102';
資料庫連結已建立。
SQL> CREATE OR REPLACE PACKAGE PA_TEST AS
2 TYPE T_NAME IS TABLE OF VARCHAR2(30);
3 END;
4 /
程式包已建立。
SQL> SET SERVEROUT ON SIZE 1000000
SQL> DECLARE
2 V_NAME PA_TEST.T_NAME;
3 BEGIN
4 P_TEST@YTK102.YTK_THINKPAD(V_NAME);
5 FOR I IN 1..V_NAME.COUNT LOOP
6 DBMS_OUTPUT.PUT_LINE(V_NAME(I));
7 END LOOP;
8 END;
9 /
P_TEST@YTK102.YTK_THINKPAD(V_NAME);
*第 4 行出現錯誤:
ORA-06550: 第 4 行, 第 2 列:
PLS-00306: 呼叫 'P_TEST' 時引數個數或型別錯誤
ORA-06550: 第 4 行, 第 2 列:
PL/SQL: Statement ignored
對於遠端儲存過程,即使傳遞完全相同的集合資料型別,也是會報錯的,這是由於變數的定義在本地,Oracle無法確定本地變數和遠端變數是相同的。
對於這種情況,可以利用遠端型別來進行變數的宣告:
SQL> DECLARE
2 V_NAME PA_TEST.T_NAME@YTK102.YTK_THINKPAD;
3 BEGIN
4 P_TEST@YTK102.YTK_THINKPAD(V_NAME);
5 FOR I IN 1..V_NAME.COUNT LOOP
6 DBMS_OUTPUT.PUT_LINE(V_NAME(I));
7 END LOOP;
8 END;
9 /
T_BLOB
T
T_PK
MLOG$_T
MLOG$_T_BLOB
MLOG$_T_PK
T2
RUPD$_T_PK
PL/SQL 過程已成功完成。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4227/viewspace-69457/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 儲存過程 傳 datatable儲存過程
- 小程式 - 陣列追加兼本地儲存陣列
- 本地MinIO儲存服務Java遠端呼叫上傳檔案Java
- lightdb新特性--相容oracle儲存過程的聯合陣列Oracle儲存過程陣列
- Java 從陣列來看值傳遞和引用傳遞Java陣列
- 000 上傳本地庫到Github遠端庫過程全記錄Github
- mysql和orcale的儲存過程和儲存函式MySql儲存過程儲存函式
- 從程式中傳遞開始日期與結束日期至儲存過程儲存過程
- php url傳遞陣列PHP陣列
- 在Entity Framework中使用儲存過程Framework儲存過程
- MySQL 儲存過程和函式MySql儲存過程函式
- MySQL儲存過程和函式MySql儲存過程函式
- 儲存raid5陣列兩塊盤掉線的解決過程AI陣列
- Oracle儲存過程乾貨(一):儲存過程基礎Oracle儲存過程
- SQL 儲存過程裡呼叫另一個儲存過程SQL儲存過程
- arrilist陣列和collections儲存學生排序陣列排序
- 日常學習儲存--陣列和指標陣列指標
- 2、JSP實現資料傳遞和儲存JS
- 儲存過程與儲存函式儲存過程儲存函式
- Shell自學二(引數傳遞和陣列)陣列
- SQLSERVER儲存過程SQLServer儲存過程
- 呼叫儲存過程儲存過程
- mysql 儲存過程MySql儲存過程
- unidac儲存過程儲存過程
- firedac儲存過程儲存過程
- Oracle儲存過程Oracle儲存過程
- IBM X3650M3儲存raid陣列癱瘓的恢復過程IBMAI陣列
- MySQL入門--儲存過程(PROCEDURE)和儲存函式(FUNCTION)MySql儲存過程儲存函式Function
- oracle儲存過程和觸發器Oracle儲存過程觸發器
- MySQL儲存過程的建立和使用MySql儲存過程
- SQL Server資料庫遠端更新目標表資料的儲存過程SQLServer資料庫儲存過程
- 本地儲存-系統和保留-系統檔案佔用儲存空間過大的解決方式
- 如何用 scp 在本地和遠端主機之間複製檔案
- MySQL中陣列的儲存MySql陣列
- JdbcTemplate調儲存過程JDBC儲存過程
- 造數儲存過程儲存過程
- 儲存過程——遊標儲存過程
- JAVA儲存過程(轉)Java儲存過程
- MySQL之儲存過程MySql儲存過程