MySQL控制流函數(shù)(-if?,elseif,else,case...when)
前言
不管是任何的編程語言,邏輯判斷是必不可缺的一個板塊;在Python、C、java這些火熱的編程語言下,邏輯判斷也是編程語言的一個亮點。
IF(expr1,expr2,expr3) 簡單邏輯判斷
如果第一個條件成立,那么就返回expr2,如果條件不成立,那么就返回expr3
IFNULL(v1,v2) 空值替換
如果 v1 的值不為 NULL,則返回 v1,否則返回 v2。
??ISNULL(expression) 空值檢測
判斷表達式是否為 NULL
如果為空就會返回1,不為空就會返回0,有時候我們用于邏輯判斷,或者循環(huán)語句的時候可以采用
??NULLIF(expr1, expr2) 字符串比較
比較兩個字符串,如果字符串 expr1 與 expr2 相等 返回 NULL,否則返回 expr1
但是在應用型的編程中,第一個還是用的比較的多,那么有的人就會想,有時候我們有多個條件需要比較的,那么這個方法就無法實現(xiàn)了,又該如何去實現(xiàn)呢?
??case 函數(shù)
CASE expression WHEN condition1 THEN result1 WHEN condition2 THEN result2 ... WHEN conditionN THEN resultN ELSE result END
CASE 表示函數(shù)開始,END 表示函數(shù)結束。如果 condition1 成立,則返回 result1, 如果 condition2 成立,則返回 result2,當全部不成立則返回 result,而當有一個成立之后,后面的就不執(zhí)行了。
傳入一個參數(shù)即可,后面我們在寫存儲過程(函數(shù))的時候,可以充分的應用
這里沒有傳參,知識按照邏輯判斷進行,如果為真那么就會返回結果,如果第一個條件就已經(jīng)滿足了,那么就不會執(zhí)行后續(xù)的判斷了
?? 實操案例
準備數(shù)據(jù)
-- 創(chuàng)建訂單表 create table orders( oid int primary key, -- 訂單id price double, -- 訂單價格 payType int -- 支付類型(1:微信支付 2:支付寶支付 3:銀行卡支付 4:其他) ); insert into orders values(1,1200,1); insert into orders values(2,1000,2); insert into orders values(3,200,3); insert into orders values(4,3000,1); insert into orders values(5,1500,2);
我們可以通過兩種方式的語法來講我們的支付方式顯示出現(xiàn),因為在業(yè)務場景中我們?yōu)榱吮WC數(shù)據(jù)的有效性和保密性,有些數(shù)據(jù)我們會公司內(nèi)部的編碼實現(xiàn),那么需要將其展示到老板的眼前的時候,這個時候就需要你來了
上述分別是用了等值判斷和值的映射去實現(xiàn),一般我更喜歡使用第一種,因為有時候還可以范圍運算
學到這里的小伙伴,可能就會疑問為什么,MySQL編程中如此的單一了,如果你覺得單一,那么你肯定是再想為什么不能實現(xiàn)控制流語句呢?
??IF ELSE 做為流程控制語句使用
這個一般和存儲過程搭配使用,相對于Python中的函數(shù),存儲過程就是函數(shù)
IF search_condition THEN statement_list [ELSEIF search_condition THEN] statement_list ... [ELSE statement_list] END IF
與PHP中的IF語句類似,當IF中條件search_condition成立時,執(zhí)行THEN后的statement_list語句,否則判斷ELSEIF中的條件,成立則執(zhí)行其后的statement_list語句,否則繼續(xù)判斷其他分支。當所有分支的條件均不成立時,執(zhí)行ELSE分支。search_condition是一個條件表達式,可以由“=、<、<=、>、>=、!=”等條件運算符組成,并且可以使用AND、OR、NOT對多個表達式進行組合。
注意:IF作為一條語句,在END IF后需要加上分號“;”以表示語句結束,其他語句如CASE、LOOP等也是相同的。
例如:
SELECT olddb.STATUS INTO @status_temp FROM olddb.checklist WHERE ID = NEW.ID - 1000000; IF @status_temp < 5 THEN SET NEW.status = @status_temp +1; ELSEIF @status_temp = 5 THEN SET NEW.status = 7; ELSEIF @status_temp = 6 THEN SET NEW.status = 10; ELSEIF @status_temp = 7 THEN SET NEW.status = 11; END IF;
到此這篇關于MySQL控制流函數(shù)(-if ,elseif,else,case...when)的文章就介紹到這了,更多相關MySQL控制流函數(shù) 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
關于MYSQL 你需要知道的數(shù)據(jù)類型和操作數(shù)據(jù)表
這篇文章主要介紹了關于MYSQL中數(shù)據(jù)類型的知識和操作數(shù)據(jù)表的方法,文中講解非常詳細供大家參考學習,感興趣的朋友可以了解下2020-06-06淺談Using filesort和Using temporary 為什么這么慢
本文主要介紹了Using filesort和Using temporary為什么這么慢,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02深入理解MySQL數(shù)據(jù)類型的選擇優(yōu)化
這篇文章主要介紹了深入理解MySQL數(shù)據(jù)類型的選擇優(yōu)化,MySQL數(shù)據(jù)類型是定義列中可以存儲什么數(shù)據(jù)以及該數(shù)據(jù)實際怎樣存儲的基本規(guī)則,正確的選擇數(shù)據(jù)庫字段的字段類型對于數(shù)據(jù)庫性能有很大的影響2022-08-08mysql常用日期時間/數(shù)值函數(shù)詳解(必看)
下面小編就為大家?guī)硪黄猰ysql常用日期時間/數(shù)值函數(shù)詳解(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06mysql show processlist 顯示mysql查詢進程
processlist命令的輸出結果顯示了有哪些線程在運行,可以幫助識別出有問題的查詢語句,兩種方式使用這個命令2012-03-03出現(xiàn)錯誤mysql Table ''performance_schema...解決辦法
這篇文章主要介紹了解決出現(xiàn)錯誤mysql Table 'performance_schema.session_variables' doesn't exist的相關資料,需要的朋友可以參考下2017-04-04