mysql 特殊函数

来源:互联网 发布:女生学金融 知乎 编辑:程序博客网 时间:2024/06/11 20:37

PS:可能下面的函数有些不是mysql的函数

SQL中 nvl()、coalesce()、decode()这三个函数,如果只是判断非空的话,哪一个效率相比较高?
nvl(bonus,0) 意思是 如果 bonus is null , 那么返回 0, 否则返回 bonus
coalesce(bonus,0,1) 意思是 返回 参数列表中, 第一个非 空的数据。
也就是相当于, 如果 bonus is null , 那么返回 0, 否则返回 bonus。
这里的最后一个参数 1, 目测是打酱油的。
coalesce(bonus,null,0) 意思是 返回 参数列表中, 第一个非 空的数据。
也就是相当于, 如果 bonus is null , 那么第2个参数还是 null, 最后返回第3个参数 0
decode(name,‘apple’,0) 意思是, 如果 name = ‘apple’ 那么返回 0
否则的话 , 就是返回 null 了。
我知道他们的区别,只是不知道单个字段判空的时候,他们的效率比较的顺序是?

0 0