SQL ISNULL()、NVL()、IFNULL() 和 COALESCE() 函数
请看下面的 “Products” 表:
P_Id | ProductName | UnitPrice | UnitsInStock | UnitsOnOrder |
---|---|---|---|---|
1 | Jarlsberg | 10.45 | 16 | 15 |
2 | Mascarpone | 32.56 | 23 | |
3 | Gorgonzola | 15.67 | 9 | 20 |
假如 “UnitsOnOrder” 是非必输的,而且可以包含 NULL 值。
咱们使用下面的 SELECT 语句:
SELECT ProductName,UnitPrice*(UnitsInStock+UnitsOnOrder)
FROM Products
在上面的实例中,如果有 “UnitsOnOrder” 值是 NULL,那么结果是 NULL。
微软的 ISNULL() 函数用于规定如何处理 NULL 值。
NVL()、IFNULL() 和 COALESCE() 函数也可以达到相同的结果。
在这里,咱们希望 NULL 值为 0。
下面,如果 “UnitsOnOrder” 是 NULL,则不会影响计算,因为如果值是 NULL 则 ISNULL() return 0:
SQL Server / MS Access
SELECT ProductName,UnitPrice*(UnitsInStock+ISNULL(UnitsOnOrder,0))
FROM Products
Oracle
Oracle 没有 ISNULL() 函数。不过,咱们可以使用 NVL() 函数达到相同的结果请在输出结果查看
SELECT ProductName,UnitPrice*(UnitsInStock+NVL(UnitsOnOrder,0))
FROM Products
MySQL
MySQL 也拥有类似 ISNULL() 的函数。不过它的工作方式与微软的 ISNULL() 函数有点不同。
在 MySQL 中,咱们可以使用 IFNULL() 函数,请在输出结果查看
SELECT ProductName,UnitPrice*(UnitsInStock+IFNULL(UnitsOnOrder,0))
FROM Products
或者咱们可以使用 COALESCE() 函数,请在输出结果查看
SELECT ProductName,UnitPrice*(UnitsInStock+COALESCE(UnitsOnOrder,0))
FROM Products
本专栏所有文章
寄语
本文有榴莲酱CSDN原创,欢迎点赞、转载,博客地址:https://blog.csdn.net/qq441540598
- 挥霍,就是把自己不珍惜的东西拿出来与人分享;慷慨,就是把自己最珍贵的东西拿出来与人分享。
- 文明可以改变爱情的方式,却永远不能扼杀爱情。(林语堂)
- 让信心在心底复苏,让勇气在胸中激荡,让热血在体内沸腾,让斗志在四肢燃烧,让蓝图在脑海浮现,让脚步在未来驰骋。愿你努力,成就精彩。
- 友谊是天地间最可宝贵的东西,深挚的友谊是人生最大的一种安慰。
- 谈一场恋爱,跳一场探戈,开始的第一步都是学会让步。有的人把你的心都掏了,你还假装不疼,那是因为你爱。耐心点,坚强点,总有一天,你承受过的疼痛会有助于你。