mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL
來源:懂視網(wǎng)
責(zé)編:小采
時間:2020-11-09 19:07:03
mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL
mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL:bitsCN.com IFNULL(expr1,expr2) 如果expr1不是NULL,IFNULL()返回expr1,否則它返回expr2。IFNULL()返回一個數(shù)字或字符串值,取決于它被使用的上下文環(huán)境。SELECT IFNULL(1,0); // 1 SELECT IFNULL(0,10); // 0 SEL
導(dǎo)讀mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL:bitsCN.com IFNULL(expr1,expr2) 如果expr1不是NULL,IFNULL()返回expr1,否則它返回expr2。IFNULL()返回一個數(shù)字或字符串值,取決于它被使用的上下文環(huán)境。SELECT IFNULL(1,0); // 1 SELECT IFNULL(0,10); // 0 SEL

bitsCN.com
IFNULL(expr1,expr2)
如果expr1不是NULL,IFNULL()返回expr1,否則它返回expr2。IFNULL()返回一個數(shù)字或字符串值,取決于它被使用的上下文環(huán)境。
SELECT IFNULL(1,0); // 1 SELECT IFNULL(0,10); // 0 SELECT IFNULL(1/0,10); // 10 SELECT IFNULL(1/0,yes); // yes
IF(expr1,expr2,expr3)
如果expr1是TRUE(expr1<>0且expr1<>NULL),那么IF()返回expr2,否則它返回expr3。IF()返回一個數(shù)字或字符串值,取決于它被使用的上下文。
SELECT IF(1>2,2,3); // 3 SELECT IF(1<2,yes,no); // yes SELECT IF(strcmp(test,test1),yes,no); // no
expr1作為整數(shù)值被計算,它意味著如果你正在測試浮點或字符串值,你應(yīng)該使用一個比較操作來做。
SELECT IF(0.1,1,0); // 0 SELECT IF(0.1<>0,1,0); // 1
在上面的第一種情況中,IF(0.1)返回0,因為0.1被變換到整數(shù)值, 導(dǎo)致測試IF(0)。這可能不是你期望的。在第二種情況中,比較測試原來的浮點值看它是否是非零,比較的結(jié)果被用作一個整數(shù)。
CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ...] [ELSE result] END
CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END
第一個版本返回result,其中value=compare-value。第二個版本中如果第一個條件為真,返回result。如果沒有匹配的result值,那么結(jié)果在ELSE后的result被返回。如果沒有ELSE部分,那么NULL被返回。
SELECT CASE 1 WHEN 1 THEN "one" WHEN 2 THEN "two" ELSE "more" END; // "one" SELECT CASE WHEN 1>0 THEN "true" ELSE "false" END; // "true" SELECT CASE BINARY "B" WHEN "a" THEN 1 WHEN "b" THEN 2 END; // NULL
bitsCN.com
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL
mysql的IFNULL、IF、CASE...WHEN...THEN...函數(shù)的使用講解_MySQL:bitsCN.com IFNULL(expr1,expr2) 如果expr1不是NULL,IFNULL()返回expr1,否則它返回expr2。IFNULL()返回一個數(shù)字或字符串值,取決于它被使用的上下文環(huán)境。SELECT IFNULL(1,0); // 1 SELECT IFNULL(0,10); // 0 SEL