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