獲取存儲過程if
『壹』 oracle 的存儲過程if怎麼嵌套啊
我給你舉個例子:
--配送量(萬箱)
select
sum(QUANTITY_SUM)
into
quantity_sum
from
DWV_OUT_DIST_BILL
where
to_char(DIST_DATE,'YYYYMM')=month
;
if
quantity_sum
is
null
then
quantity_sum:=0;
end
if;
--轉換成萬箱
quantity_sum
:=quantity_sum/50/10000;
『貳』 存儲過程 if語句的使用
那就要看一下你的readerinfo表上面是不是有觸發器了:
create proc sp_test
as
update
set rrrid=case when rrrid=0 then 20 else 0 end
where readerid='s001'
『叄』 存儲過程中的if語句該如何寫
如果像你這個只是單純的or的話,這兩種寫法應該都可以。 可是如果是有and又有or,那麼就需要你先把這個條件的先後分清楚了,這樣的情況,肯定需要括弧括清楚每一層。
『肆』 oracle存儲過程IF判斷的問題
問題1:當你傳入37
時,IF
FLAG>5
已經滿足條件了,直接V_VALUE
:=1;,不會繼續判斷了。然後就調到end
if。可以按f9調試,不信一步步看它的執行過程。
問題2:IF
V_NULL=NULL,不是這樣寫,是IF
V_NULL
IS
NULL
,就會輸出888啦。
declare @proc_text varchar(max)
DECLARE get_proc_text_cursor CURSOR FOR
SELECT 'if object_id(N'''+ [name] +''') is not null drop proc ' + [name] + CHAR(10) + CHAR(13) + ' GO ' + CHAR(10) + CHAR(13) + definition + CHAR(10) + CHAR(13) +' GO'
FROM sys.sql_moles
inner join sysobjects on sys.sql_moles.object_id = sysobjects.id and type='p'
OPEN get_proc_text_cursor
FETCH NEXT FROM get_proc_text_cursor
INTO @proc_text
WHILE @@FETCH_STATUS = 0
BEGIN
print @proc_text
FETCH NEXT FROM get_proc_text_cursor
INTO @proc_text
END
CLOSE get_proc_text_cursor
DEALLOCATE get_proc_text_cursor
『陸』 oracle 存儲過程里的if else
ifS_date=4then
p_temp();
elsifS_date!=4then
p_temp2();
endif;
『柒』 mysql中要新建一個存儲過程,,if語句的判斷條件
BEGIN
IFEXISTS(select1fromrw_yzs_Staticwherepagetype=i_pagetypeandcatalogCode=i_catalogCodeandserviceCode=i_serviceCodeandserviceName=i_serviceName)THEN
updaterw_yzs_StaticsetserviceCode=i_serviceCode,serviceName=i_serviceName,zgbb=i_zgbb,sxmc=i_sxmc,cnqx=i_cnqx,sfbz=i_sfbz,dz=i_dz,bldx=i_bldx,bltj=i_bltj,sxcl=i_sxcl,ckbllc=i_ckbllc,wsbllc=i_wsbllc,blsx=i_blsx,blyj=i_blyj,bz=i_bz,updatetime=NOW()
wherepagetype=i_pagetypeandcatalogCode=i_catalogCodeandserviceCode=i_serviceCodeandserviceName=i_serviceName;
ELSE
INSERTINTOrw_yzs_Static(pagetype,divisioncode,divisionname,catalogCode,catalogName,serviceCode,serviceName,orgGroup,zgbb,sxmc,cnqx,sfbz,dz,bldx,bltj,sxcl,ckbllc,wsbllc,blsx,blyj,bz,updatetime)
VALUES(i_pagetype,i_divisioncode,i_divisionname,i_catalogCode,i_catalogName,i_serviceCode,i_serviceName,i_orgGroup,i_zgbb,i_sxmc,i_cnqx,i_sfbz,i_dz,i_bldx,i_bltj,i_sxcl,i_ckbllc,i_wsbllc,i_blsx,i_blyj,i_bz,now());
ENDIF;
END
例子與回答無關:
這里應該用case when then 這類的吧
這里給個思路,具體用法還是自己去網路吧。應該太多了這種教學。
select case 學分 when <60 then xf=0 from xscj where 學號=xh and 課程名稱 =kcmc
你里你應該新增一個變數來記錄成績的值 才能對此進行IF判斷
『捌』 存儲過程的if,else怎麼寫
不同的資料庫中,存儲過程中if else 語句寫法有一些差別。
如果是SQLServer資料庫,存儲過程的if, else語句可以這樣寫:
ifa>b
Begin
print'a'
End
Elseifa<b
Begin
print'b'
End
Else
Begin
print'代碼'
End
Oracle 採用下面這種寫法:
IFtestvalue>100THEN
dbms_output.put_line('100+');
ELSIFtestvalue=100THEN
dbms_output.put_line('100');
ELSE
dbms_output.put_line('100-');
ENDIF;
DB2, MYSQL 是下面這種寫法: ( 與 Oracle 區別在於那個 ELSIF )
IFp_val>100THEN
INSERTINTOoutput_debugVALUES('100+');
ELSEIFp_val=100THEN
INSERTINTOoutput_debugVALUES('100');
ELSE
INSERTINTOoutput_debugVALUES('100-');
ENDIF;
『玖』 存儲過程里if判斷問題
p_cntnumber;
begin
selectcount(1)intop_cntfromtest2;
ifp_cnt>0then
deletefromtest2;
endif;
selectcount(1)intop_cntfromtest4;
ifp_cnt>0then
deletefromtest4;
endif;
insertintotest2
select*fromtest1;
insertintotest4
select*fromtest3;
commit;
end;
『拾』 oracle 存儲過程 if語句
&&用and表示,如:
if 1=1 and 2=2 then
...
end;
||用or表示。
!用not表示。