這篇文章主要介紹了MySQL講解條件判斷函數的示例,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
函數:
(1)IF(expr,v1,v2)函數
(2)IFNULL(v1,v2)函數
(3)CASE函數
(相關免費學習推薦:mysql視頻教程)
在if(expr,v1,v2)函數中,若表達式expr是true(expr<>0 and epr<>null)返回v1,否則返回v2。
【例】使用if()函數進行條件判斷,SQL語句如下:
mysql> select if(1>2,2,3), -> if(1<2,'yes','no'), -> if(strcmp('test','test1'),'no','yes');+-------------+--------------------+---------------------------------------+| if(1>2,2,3) | if(1<2,'yes','no') | if(strcmp('test','test1'),'no','yes') |+-------------+--------------------+---------------------------------------+| 3 | yes | no |+-------------+--------------------+---------------------------------------+1 row in set (0.00 sec)
在ifnull(v1,v2)中,假如v1不為null,則ifnull()的返回值為v1,否則返回值為v2。
如果v1或v2中只有一個明確是null,則if()函數的結果類型為非null表達式的結果類型。
【例】使用ifnull()函數進行條件判斷,SQL語句如下:
mysql> select ifnull(1,2),ifnull(null,10),ifnull(1/0,'wrong');+-------------+-----------------+---------------------+| ifnull(1,2) | ifnull(null,10) | ifnull(1/0,'wrong') |+-------------+-----------------+---------------------+| 1 | 10 | wrong |+-------------+-----------------+---------------------+1 row in set (0.00 sec)
1.case expr when v1 then r1 [ when v2 then r2] [else rn] end
該函數表示,如果expr值等于某個vi,則返回對應位置then后面的結果,如果與所有值都不相等,則返回else后面的m。
【例】使用case value when語句執行分支操作,SQL語句如下;
mysql> select case 2 when 1 then 'one' when 2 then 'two' else 'more' end;+------------------------------------------------------------+| case 2 when 1 then 'one' when 2 then 'two' else 'more' end |+------------------------------------------------------------+| two |+------------------------------------------------------------+1 row in set (0.00 sec)
2.case when v1 then rv [when v2 then r2] else rn] end
該函數表示,某個vi值為true時,返回對應位置then后面的結果,如果所有值都不為true,則返回else后面的rn。
一個case表達式的默認返回值類型是任何返回值的相容集合類型,具體情況視其所在語境而定。
【例】使用case when 語句執行分支操作,SQL語句如下:
mysql> select case when 1<0 then 'true' else 'false' end;+--------------------------------------------+| case when 1<0 then 'true' else 'false' end |+--------------------------------------------+| false |+--------------------------------------------+1 row in set (0.00 sec)
感謝你能夠認真閱讀完這篇文章,希望小編分享的“MySQL講解條件判斷函數的示例”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。