首頁 >資料庫 >mysql教程 >MySQL講解條件判斷函數

MySQL講解條件判斷函數

coldplay.xixi
coldplay.xixi轉載
2021-03-03 09:39:492587瀏覽

MySQL講解條件判斷函數

函數:

(1)IF(expr,v1,v2)函數
(2)IFNULL(v1,v2)函數
(3 )CASE函數

(相關免費學習推薦:mysql影片教學

(1)if(expr,v1,v2)函數
  • 在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,&#39;yes&#39;,&#39;no&#39;),
    -> if(strcmp('test','test1'),'no','yes');+-------------+--------------------+---------------------------------------+| if(1>2,2,3) | if(1<2,&#39;yes&#39;,&#39;no&#39;) | if(strcmp(&#39;test&#39;,&#39;test1&#39;),&#39;no&#39;,&#39;yes&#39;) |+-------------+--------------------+---------------------------------------+|           3 | yes                | no                                    |+-------------+--------------------+---------------------------------------+1 row in set (0.00 sec)

(2)ifnull(v1,v2)函數
  • #在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)

(3)case函數
##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教學(影片)

以上是MySQL講解條件判斷函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除