oracle存儲過程輸出參數
㈠ 關於調用帶輸出參數的oracle存儲過程
可以通過以下方式來進行帶參數存儲過程執行。
sql">SQL>createorreplaceproceresp_pro10
2(spnoinnumber,spnameoutvarchar2)is
3begin
4select'ename'intospnamefromal;
5end;
6/
過程已創建。
SQL>setserveroutputon
SQL>DECLARE
2spnonumber;
3spnamevarchar2(10);
4BEGIN
5sp_pro10(spno,spname);
6
7dbms_output.put_line(spname);
8END;
9/
ename
PL/SQL過程已成功完成。
㈡ oracle存儲過程如何輸出信息
可用DBMS_OUTPUT.PUT_LINE()對存儲過程的進行輸出。
編寫存儲過程:
create or replace procere test_pro(in_num number)
as
M number;
begin
M := in_num;
if 0 < M then
dbms_output.put_line('輸出SQL語句1');
elsif M < 3 then
dbms_output.put_line('輸出SQL語句2');
else
dbms_output.put_line('nothing');
end if;
end;
(2)oracle存儲過程輸出參數擴展閱讀;
存儲在資料庫的數據字典中,存儲在當前的應用中安全性由資料庫提供安全保證,必須通過授權才能使用存儲子程序,安全性靠應用程序來保證,如果能執行應用程序,就能執行該子程序。模式描述IN參數用來從調用環境中向存儲過程傳遞值,不能給IN參數賦值,給此參數傳遞的值可以是常量、有值的變數、表達式等。
㈢ oracle 存儲過程 out參數的值怎麼使用
輸出模式的參數,用於輸出值,會忽略傳入的值。在子程序內部可以對其進行修改。
輸出:子程序執行完畢後,out模式參數最終的值會賦值給調用時對應的<實參變數>。
注意:out模式參數的調用,必須通過變數。
--測試out模式的存儲過程
CREATEORREPLACEPROCEDUREpro(p3OUTINT)ASBEGIN
println(p3);--p3會忽略傳入的值
p3:=33;--設定存儲過程調用後的值
END;
DECLARE
var3INT:=30;--聲明一個變數用於設定存儲過程調用前的值BEGIN--
pro(30);--error,20對應過程中out模式的參數,out會輸出結果給調用的實參,但是20不能作為賦值目標
println('存儲過程調用前的值:'||var3);
pro(var3);--調用pro存儲過程重新賦值;調用過程,如果過程形參是out模式,必須採用變數實參
println('存儲過程調用後的值:'||var3);
END;
㈣ oracle 中用什麼命令執行一個帶參數的存儲過程
具體如下:
1、第一步,創建一個新的存儲過程,見下圖,轉到下面的步驟。
㈤ oracle帶參(傳入,傳出)的存儲過程怎麼執行
1、新建存儲過程,Create or ReplaceProcere CHK_SYS_EMP 檢查系統工號。
㈥ ORACLE 獲取包中存儲過程或函數的參數
該包用於 動態獲取包中存儲過程或者函數的參數。
create or replace package SF_GET_ARGUMENTS_PKG is
-- Author : SANFU
-- Created : 2020/7/22 14:40:49
-- Purpose : 動態獲取包中存儲過程或者函數的參數
PROCEDURE get_arguments(p_pkg_name in VARCHAR2, p_obj_name in VARCHAR2);
PROCEDURE pf_get_arguments(p_pkg_name in VARCHAR2,
茄脊差 p_obj_name in VARCHAR2);
end SF_GET_ARGUMENTS_PKG;
/
create or replace package body SF_GET_ARGUMENTS_PKG is
/*============================================*
* Author : CZH
* Created : 2020-07-22 15:00:12
* ALERTER :
* ALERTER_TIME :
* Purpose :
* Arg_number : 2
* P_PKG_NAME :包名
* P_OBJ_NAME :存儲過程名或函數名
*============================================*/
PROCEDURE get_arguments(p_pkg_name in VARCHAR2, p_obj_name in VARCHAR2) IS
v_pkg_name varchar2(100) := upper(p_pkg_name);
v_obj_name varchar2(100) := upper(p_obj_name);
v_arg_number NUMBER;
cursor data_cur is
select t.PACKAGE_NAME,
t.OBJECT_NAME,
t.ARGUMENT_NAME,
t.IN_OUT,
count(t.ARGUMENT_NAME) over(PARTITION BY t.OBJECT_NAME) arg_number,
row_number() over(partition by t.OBJECT_NAME order by t.POSITION asc) rank_position
顫皮 from sys.user_arguments t
where t.PACKAGE_NAME = v_pkg_name
and t.OBJECT_NAME = v_obj_name
and t.POSITION <> 0;
begin
select count(1)
into v_arg_number
from sys.user_arguments t
where t.PACKAGE_NAME = v_pkg_name
and t.OBJECT_NAME = v_obj_name
and t.POSITION <野虧> 0;
dbms_output.put_line('/*============================================*');
dbms_output.put_line(' * Author : SANFU');
dbms_output.put_line(' * Created : ' ||
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS'));
dbms_output.put_line(' * ALERTER : ');
dbms_output.put_line(' * ALERTER_TIME : ');
dbms_output.put_line(' * Purpose : ');
dbms_output.put_line(' * Obj_Name : ' || v_obj_name);
dbms_output.put_line(' * Arg_Number : ' || v_arg_number);
for rec in data_cur loop
dbms_output.put_line(' * ' || rec.ARGUMENT_NAME || ' :');
end loop;
dbms_output.put_line(' *============================================*/');
end get_arguments;
--獲取參數
PROCEDURE pf_get_arguments(p_pkg_name in VARCHAR2,
p_obj_name in VARCHAR2) IS
v_pkg_name varchar2(100) := upper(p_pkg_name);
v_obj_name varchar2(100) := upper(p_obj_name);
v_attr varchar2(100);
cursor data_cur is
select t.PACKAGE_NAME,
t.OBJECT_NAME,
t.ARGUMENT_NAME,
t.IN_OUT,
count(t.ARGUMENT_NAME) over(PARTITION BY t.OBJECT_NAME) arg_number,
row_number() over(partition by t.OBJECT_NAME order by t.POSITION asc) rank_position
from sys.user_arguments t
where t.PACKAGE_NAME = v_pkg_name
and t.OBJECT_NAME = v_obj_name
and t.POSITION <> 0;
begin
dbms_output.put_line(v_pkg_name || '.' || v_obj_name || '(');
for rec in data_cur loop
if rec.in_out = 'IN' then
v_attr := '';
elsif rec.in_out = 'OUT' then
v_attr := '';
elsif rec.in_out = 'IN/OUT' then
v_attr := '';
end if;
if data_cur%ROWCOUNT = rec.arg_number then
dbms_output.put_line(lower(rec.ARGUMENT_NAME) || ' =>' ||
' ' || v_attr || lower(rec.ARGUMENT_NAME));
else
dbms_output.put_line(lower(rec.ARGUMENT_NAME) || ' =>' ||
' ' || v_attr || lower(rec.ARGUMENT_NAME) || ',');
end if;
end loop;
dbms_output.put_line(');');
end pf_get_arguments;
end SF_GET_ARGUMENTS_PKG;
/
㈦ plsql調用oracle存儲過程有輸入參數和輸出參數 sql語句怎麼寫如題 謝謝了
假設第一個參數為in參數,每二個參數為out參數:
variable
x
number;
//定義一個綁定變數
exec
過程(1,:x)
//1為輸入參數,x為輸出參數,過程執行後x就得到輸出值了。
print
x
//看結果