存儲過程if嵌套
❶ 存儲過程 if語句的使用
那就要看一下你的readerinfo表上面是不是有觸發器了:
create proc sp_test
as
update
set rrrid=case when rrrid=0 then 20 else 0 end
where readerid='s001'
❷ 請教ms sqlserver存儲過程如何寫多個if語句
select @user_blog_lock='yes'elseselect @user_blog_lock='no'GO這樣寫,後面那二條語句是沒有執行到的。用到else if 是錯誤的語法,如果都都用if,第二條語句以後都不能執行了
變數的輸入是對的。
第二、三條IF語句是不能執行了。看聯機叢書 F1
-----------------------IF...ELSE在執行 Transact-SQL 語句時強加條件。如果條件滿足(布爾表達式返回 TRUE 時),則在 IF 關鍵字及其條件之後執行 Transact-SQL 語句。可選的 ELSE 關鍵字引入備用的 Transact-SQL 語句,當不滿足 IF 條件時(布爾表達式返回 FALSE),就執行這個語句。
語法IF Boolean_expression
{ sql_statement | statement_block }[ ELSE{ sql_statement | statement_block } ]參數Boolean_expression
是返回 TRUE 或 FALSE 的表達式。如果布爾表達式中含有 SELECT 語句,必須用圓括弧將 SELECT 語句括起來。
{sql_statement | statement_block}
Transact-SQL 語句或用語句塊定義的語句分組。除非使用語句塊,否則 IF 或 ELSE 條件只能影響一個 Transact-SQL 語句的性能。若要定義語句塊,請使用控制流關鍵字 BEGIN 和 END。如果在 IF...ELSE 塊的 IF 區和 ELSE 區都使用了 CREATE TABLE 語句或 SELECT INTO 語句,那麼 CREATE TABLE 語句或 SELECT INTO 語句必須指向是相同的表名。
注釋IF...ELSE 結構可以用在批處理中,存儲過程中(經常使用這種結構測試是否存在著某個參數),以及特殊查詢中。
可以在其它 IF 之後或在 ELSE 下面,嵌套另一個 IF 測試。對於嵌套層數沒有限制。
示例
A. 使用一個 IF...ELSE 塊
下面的示例顯示帶有語句塊的 IF 條件。如果書的平均價格不低於 $15,那麼就顯示文本:Average title price is more than $15.
USE pubsIF (SELECT AVG(price) FROM titles WHERE type = 'mod_cook') < $15BEGINPRINT 'The following titles are excellent mod_cook books:'PRINT ' 'SELECT SUBSTRING(title, 1, 35) AS Title
FROM titles
WHERE type = 'mod_cook'ENDELSEPRINT 'Average title price is more than $15.'
下面是結果集:
The following titles are excellent mod_cook books:Title-----------------------------------
Silicon Valley Gastronomic Treats
The Gourmet Microwave
(2 row(s) affected)
B. 使用多個 IF...ELSE 塊
下面的示例使用了兩個 IF 塊。如果書的平均價格不低於 $15,那麼就顯示文本:Average title price is more than $15。如果現代烹調書的平均價格高於 $15,則顯示現代烹調書價格昂貴的語句。
USE pubsIF (SELECT AVG(price) FROM titles WHERE type = 'mod_cook') < $15BEGINPRINT 'The following titles are excellent mod_cook books:'PRINT ' 'SELECT SUBSTRING(title, 1, 35) AS Title
FROM titles
WHERE type = 'mod_cook'ENDELSEIF (SELECT AVG(price) FROM titles WHERE type = 'mod_cook') > $15BEGINPRINT 'The following titles are expensive mod_cook books:'PRINT ' 'SELECT SUBSTRING(title, 1, 35) AS Title
❸ mysql存儲過程中if的嵌套
前幾日寫存儲過程,使用嵌套if語句的時候,碰到一個奇怪的問題,多方找原因無果。後發現是一個很sb的問題。。。
if condition1 then
if condition1.1 then
do something1.1;
else if condition1.2 then
do something1.2;
else -- 報錯的地方
do something1.3;
endif;
else
do something2.2;
endif;
如上,else那裡一直在報錯。
使用了排除法,把else那塊去掉,仍報錯。
整個中間的if那段去掉,編譯成功。
else if和else去掉,編譯成功。
else if去掉,編譯成功。
好吧,else if的問題。elseif應該是沒有空格的!!!
排除法是個好方法,細心是個好習慣😂😂😂。。。
❹ oracle存儲過程中嵌套多個if
BEGIN
IF (1 = 1) THEN
DBMS_OUTPUT.PUT_LINE('這是第一層的if');
IF (1 = 1) THEN
DBMS_OUTPUT.PUT_LINE('這是第二層的if');
END IF;
ELSE
DBMS_OUTPUT.PUT_LINE('這是第一層的else');
END IF;
END;
這個是我測試的 不會被第一個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;
❻ 在sqlserver的存儲過程中怎樣使用if-else if
跟程序中使用差不多,if,else
if,else,只不過在sqlserver中,{}使用begin和end代替,裡面嵌套什麼的,都跟程序中寫的差不多,簡單實例如下:
declare
@a
intset
@a=1if
@a<0begin
select
'小於0'endelse
if
@a=0begin
select
'等於0'endelsebegin
if
@a>0
and
@a<1
begin
select
'大於0小於1'
end
else
begin
select
'大於1'
endend在簡單看看程序代碼:int
a=1;if(a<0){
輸出小於0;}else
if(a==0){
輸出等於0;}else{
if(a>0&&a<1)
{
輸出大於0小於1;
}
else
{
輸出大於1
}}
❼ sql server存儲過程的嵌套問題
在兩個print前面再加一條insert語句啊,把相關信息先寫到表裡,再列印信息,類似於
先建表
CREATE TABLE ERRORINFOR (username varchar(20),errorinfo varchar(50))
再加一條語句。
insert into errorinfor values(@username,'已經存在')
PRINT '用戶名:'+@username+' 已經存在!!!'
❽ 求教一下oracle存儲過程中if的嵌套使用問題
一、
if()then
if()then
end if;
end if;
二、
if()then
elsif()then
end 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;
❿ 在MYSQL存儲過程中case語句里嵌套IF語句行嗎
你的case內的if中的 getchar()應該只執行一次,用變數保存,如case『S':改為: 在switch(in)前面加個 char ch; case 'S':printf("目前無法判斷,請輸入第二個字元!\n"); ch = getchar(); if(ch=='a') printf("Saturday."); else if (ch=='u') //...