oracle存儲過程里調用存儲過程
Ⅰ oracle存儲過程里調用存儲過程
存儲過程里直接新起一行寫b(c,d);就可以,不在存儲過程中單獨執行時要call b(c,d);
Ⅱ oracle存儲過程調用另一個存儲過程
調用方法不正確
調用時沒有實參,你應該按照函數定義時參數的個數和類型給函數傳遞同樣個數和類型的參數,這是最基本的啊
你定義的是個函數,是函數就要返回值,你得用一個函數返回值同樣類型的變數去接收這個返回值
Ⅲ oracle 在存儲過程中如何正確調用另一個存儲過程
PRO_PAGINGQUERY_sql這個存儲過程是單獨創建的還是在另一個package裡面的,如果在另一個package則需要聲明
Ⅳ oracle中,一個存儲過程怎麼調用另一個存儲過程這兩個存儲過程都帶有各自的參數。直接調用似乎不行。
直接調用就可以了。舉個例子把 B 存儲過程調用A 存儲過程。
PROCEDURE A (p_1 in number,p_2 out number)
is
v_1 number;
begin
V_1:=p_1;
p_2:=v_1;
end A;
(1)如果A 與B同在一個package裡面的話。那麼 B裡面直接可以調用A
PS:如果A,B在同一個Package 中無法調用的話,那麼很可能是A,B在Spec里沒有聲明。一個package包含Spec 和Body,兩層。不能調用很可能沒有聲明。聲明後應該ok!
PROCEDURE B(p_1 in number)
is
v_result number;
begin
v_result =A(p_1);
end B;
其中v_result就是調用A的結果,A的返回值。
(2)如果A與B不在同一個package的話
那麼B在調用A 的時候,需要加上pkg的名字
比如:A 存儲過程在pkg :xxom_test_pkg 中
PROCEDURE B(p_1 in number)
is
v_result number;
begin
v_result = xxom_test_pkg .A(p_1);
end B;
----------------------------------------------------------
以上簡單介紹了存儲過程的調用。
希望對你有幫助
Ⅳ oracle中,一個存儲過程怎麼調用另一個存儲過程
已經有人回答的很專業了!x0dx0a原則就是:你要調用哪個存儲過程,就要為該存儲過程傳入它需要的參數x0dx0a它定義的幾個,你就傳入幾個x0dx0a當然參數的類型要對應上。x0dx0a還有就是如果一個存儲過程中定義了out類型的參數,當你在調用它的時候,這個out類型的參數也要參入,看它定義的是什麼類型的out參數。然後定義一個該類型的變數,傳入進去,用於接收存儲過程返回的值。然後用這個值,去做下面的邏輯。
Ⅵ oracle中怎麼在存儲過程中調用同一個包的其他存儲過程
在存儲過程或函數里調用oracle包的話,首先要有執行這個包的許可權;如果包屬於其他的用戶(不是系統包),調用時:用戶名.包名.存儲過程(參數)名或者
變數:=用戶名.包名.函數(參數);因為函數有返回值,變數類型要跟函數返回值的類型一致。
在command
下調用的話:exec
用戶名.包名.存儲過程名(參數);select
用戶名.包名.函數名(參數)
from
al;就可以了。包屬於當期用戶可以不寫用戶名。
Ⅶ oracle資料庫調用存儲過程
這個需要分情況的
如果是在應用程序(Java等)中調用存儲過程,需要根據相應語言的語法來進行。這個可以通過查找相應語言的幫助來找到。
如果是在Oracle的其他存儲過程中調用,直接寫存儲過程名就可以了。傳入相應的參數,即可執行。
如果在Oracle的命令行中,使用EXEC
存儲過程名(參數)
的方式即可調用。
如果存儲過程執行的語句寫在SQL文件中,則可以通過調用文件的方式執行,即
SQL>
@D:\SQL\example.sql的形式
Ⅷ oracle 存儲過程中調用存儲過程
一個帶參數的存儲過程。
SQL> CREATE OR REPLACE PROCEDURE HelloWorld1 (
2 p_user_name VARCHAR2
3 ) AS
4 BEGIN
5 dbms_output.put_line('Hello ' || p_user_name || '!');
6 END HelloWorld1;
7 /
Procere created.
SQL> CREATE OR REPLACE PROCEDURE CallHelloWorld1 (
2 p_user VARCHAR2
3 ) AS
4 BEGIN
5 -- 調用存儲過程的 存儲過程
6 HelloWorld1(p_user);
7 END CallHelloWorld1;
8 /
Procere created.
執行
SQL> set serveroutput on
SQL> exec CallHelloWorld1( 'Tom' );
Hello Tom!
PL/SQL procere successfully completed.
Ⅸ 在oracle中 存儲過程如何調用存儲過程
在存儲過程中直zd接使用就行了
--創建回一個存儲答過程
CREATE
OR
REPLACE
PROCEDURE
PR_NEW1
(N_NAME
VARCHAR2)
as
begin
DBMS_OUTPUT.PUT_LINE(N_NAME);
end
;
--在另一個存儲過程中調用
CREATE
OR
REPLACE
PROCEDURE
PR_NEW2
as
begin
PR_NEW1('NAME');
---
end
;