SQL
- SQL 快速参考
- SQL 注入
- Microsoft Access、MySQL 以及 SQL Server 所使用的数据类型和范围
- SQL ISNULL()、NVL()、IFNULL() 和 COALESCE() 函数
- SQL NULL 值
- SQL Date 函数
- SQL VIEW(视图)
- SQL AUTO INCREMENT 字段
- SQL ALTER TABLE 语句
- SQL CREATE INDEX 语句
- SQL DEFAULT 约束
- SQL CHECK 约束
- SQL FOREIGN KEY 约束
- SQL PRIMARY KEY 约束
- SQL UNIQUE 约束
- SQL NOT NULL 约束
- SQL 约束 (Constraints)
- SQL drop 撤销索引、撤销表以及撤销数据库
- CREATE TABLE 语句
- CREATE DATABASE 语句
- SQL SELECT INTO 语句
- SQL UNION 操作符
- SQL FULL JOIN 关键字
- SQL RIGHT JOIN 关键字
- SQL LEFT JOIN 关键字
- SQL INNER JOIN 关键字
- SQL JOIN连接查询
- SQL Alias(别名)
- SQL BETWEEN 操作符
- SQL IN 操作符
- SQL 通配符
- SQL LIKE 操作符
- SQL TOP 子句
- SQL DELETE 语句
- SQL UPDATE 语句
- SQL NULL Values(空值)
- SQL INSERT INTO 语句
- SQL ORDER BY 子句
- SQL AND & OR 运算符
- SQL WHERE 子句
SQL ISNULL()、NVL()、IFNULL() 和 COALESCE() 函数
请看下面的 "Products" 表:
P_Id | ProductName | UnitPrice | UnitsInStock | UnitsOnOrder |
---|---|---|---|---|
1 | computer | 699 | 25 | 15 |
2 | printer | 365 | 36 | |
3 | telephone | 280 | 159 | 57 |
假如 "UnitsOnOrder" 是可选的,而且可以包含 NULL 值。
我们使用如下 SELECT 语句:
SELECT ProductName,UnitPrice*(UnitsInStock+UnitsOnOrder) FROM Products
在上面的例子中,如果有 "UnitsOnOrder" 值是 NULL,那么结果是 NULL。
微软的 ISNULL() 函数用于规定如何处理 NULL 值。
NVL(), IFNULL() 和 COALESCE() 函数也可以达到相同的结果。
在这里,我们希望 NULL 值为 0。
下面,如果 "UnitsOnOrder" 是 NULL,则不利于计算,因此如果值是 NULL 则 ISNULL() 返回 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
写笔记