以前用oracle的nvl等函数很方便,mysql的不熟悉,用多少记多少了
1.如果需要对select 结果改值赋值考虑下面的函数
- IF(expr1 ,expr2 ,expr3 )
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL) ,则 IF() 的返回值为expr2 ; 否则返回值则为 expr3 。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。
- IFNULL(expr1 ,expr2 )
假如expr1 不为 NULL ,则 IFNULL() 的返回值为 expr1 ; 否则其返回值为 expr2 。IFNULL() 的返回值是数字或是字符串,具体情况取决于其所使用的语境。
- NULLIF(expr1 ,expr2 )
如果expr1 = expr2 成立,那么返回值为NULL ,否则返回值为 expr1 。这和CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END 相同。