oracle存儲過程in
⑴ oracle存儲過程,為什麼創建的時候還要傳參數不是應該調用的時候傳嗎
你理解是對的,存儲過程在創建的時候是不需要輸入參數的,只有在調用的時候才需要傳遞參數。
首先,存儲過程中你定義參數的時候沒有指定輸入輸出,vsalary IN ,vsalary ,IN 或者OUT 輸出參數。
create or replace procere p_employee(vsalary IN number,vsalary2 IN number)
as.....
vsalary 和vsalary2即為變數名,在後面游標中直接使用變數名,不需要&vsalary 和&vsalary2。
按存儲過程規范來修改一下,,祝你成功。
⑵ oracle 存儲過程中in條件傳參數
樓上的可以,不過有些語法錯誤,我改改,呵呵
---
create or replace procere pd1(p_1 number,p_2 number,p_3 number)
is
v_sql varchar2(4000);
begin
v_sql:='select * from table where id in('||p_1||','||p_2||','||p_3||')';
execute immediate v_sql;
end;
/
⑶ oracle存儲過程中循環for in是如何使用的
這樣使用的:
for
xx
in
(select
語句)
這是隱式游標,這個結構中不能帶參數,或者說普通的游標,隱式或顯式的都不能帶參數,使用參數游標或引用(動態)游標。
例如:
declare
cursor cur(C_value number) is select col_A,col_B from tableA where col_C=C_value
;
begin
for xx in cur loop
--處理
end loop;
end
(3)oracle存儲過程in擴展閱讀:
注意事項
使用for循環實現
declare
cursor
cur
is
select
*
from
tablename;
aw_row
tablename%rowtype;
begin
for
raw_row
in
cur
loop
dbms_output.put_line('test');
end
loop;
end;
for語句直接幫做了游標的打開關閉,以及判斷工作,所以比較常用。
⑷ oracle 存儲過程 sql中in變數問題
我理解樓主的意思是這樣的.這個靜態使用有問題.
如果就直接這樣執行的話,
select count(*) into v_count from t where type in(a);
應該是有問題的.
可以這樣嘗試一下:
a varchar2(N);
execute immediate 'select count(1) from t where type in('||a||')' into v_count ;
還要注意傳入的變數,引號別弄丟了...
應該是可以的,我沒有測試,很久沒有動過這些了.
⑸ 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;
(5)oracle存儲過程in擴展閱讀;
存儲在資料庫的數據字典中,存儲在當前的應用中安全性由資料庫提供安全保證,必須通過授權才能使用存儲子程序,安全性靠應用程序來保證,如果能執行應用程序,就能執行該子程序。模式描述IN參數用來從調用環境中向存儲過程傳遞值,不能給IN參數賦值,給此參數傳遞的值可以是常量、有值的變數、表達式等。
⑹ oracle存儲過程中循環for in是如何使用的
1、首先編寫存儲過程的整體結構,如下圖所示定義變數。