• 注册
当前位置:1313e > 数据库 >正文

mysql小技巧之null值映射(IF和IFNULL)到其他有意义的值

数据库关系模型创建者 - E.F.Codd博士在关系数据库理论中引入了NULL概念。 根据Dr.E.C.F.Codd的表述,NULL表示未知值或缺少信息。其中mysql还支持NULL表示缺少或不适用信息的概念。所以在数据库表中,我们可能会存储包含NULL值的数据。但是如果以报表的形式向用户呈现数据时,显示NULL值是没有意义的。所以,我们如果要使报告更可读和可理解,必须显示NULL值作为其他有意义的值,如未知,缺失或不可用(N/A),要做到这一点,我们可以使用IF函数做到。来看下语法结构:

IF(exp,exp_result1,exp_result2);

在上述表达式中,如果exp计算结果为TRUE(当exp <> 0exp <> NULL)时,IF函数返回exp_result1的值,否则返回exp_result2的值。其实,IF函数的返回值可以是字符串或数字,具体取决于exp_result1exp_result2表达式。完事我们来写个sql,感受下这个IF的效果。以下是customers表中包含了customernamestatecountry 的部分数据:

SELECT customername, state, country
FROMcustomers
ORDER BY country;

执行上面代码,得到以下结果:

+------------------------------------+---------------+--------------+
| customername                       | state         | country      |
+------------------------------------+---------------+--------------+
| Australian Collectors, Co.         | Victoria      | Australia    |
| Annas Decorations, Ltd             | NSW           | Australia    |
| Souveniers And Things Co.          | NSW           | Australia    |
| Australian Gift Network, Co        | Queensland    | Australia    |
|************** 此处省略了many many数据 *********************************|
| Handji Gifts& Co                   | NULL          | Singapore    |
| Asian Shopping Network, Co         | NULL          | Singapore    |
| SAR Distributors, Co               | Pretoria      | South Africa |
| Euro+ Shopping Channel             | NULL          | Spain        |
| Diecast Collectables               | MA            | USA          |
+------------------------------------+---------------+--------------+
122 rows in set

从上面的结果集中,我们可以看到state列的值不适用于某些客户,所以我们要使用IF函数将NULL值显示为N/A,来看下sql:

SELECT customername, IF(state IS NULL, 'N/A', state) state, country
FROMcustomers
ORDER BY country;

执行上面查询代码,得到以下结果:

+------------------------------------+---------------+--------------+
| customername                       | state         | country      |
+------------------------------------+---------------+--------------+
| Australian Collectors, Co.         | Victoria      | Australia    |
| Annas Decorations, Ltd             | NSW           | Australia    |
| Souveniers And Things Co.          | NSW           | Australia    |
| Australian Gift Network, Co        | Queensland    | Australia    |
| Australian Collectables, Ltd       | Victoria      | Australia    |
| Salzburg Collectables              | N/A           | Austria      |
| Mini Auto Werke                    | N/A           | Austria      |
| Petit Auto                         | N/A           | Belgium      |
| Royale Belge                       | N/A           | Belgium      |
|************** 此处省略了一大波数据 *********************************|
| Motor Mint Distributors Inc.       | PA            | USA          |
| Signal Collectibles Ltd.           | CA            | USA          |
| Diecast Collectables               | MA            | USA          |
+------------------------------------+---------------+--------------+
122 rows in set

说实话,除了IF函数外,mysql提供了IFNULL函数,可以直接处理NULL值。 以下是IFNULL函数的语法:

IFNULL(exp,exp_result);

我们来重新写下sql:

SELECT customername, IFNULL(state,"N/A") state, country
FROM customers
ORDER BY country;

在上面的sql中,如果exp计算结果为NULL值,则IFNULL函数返回exp_result表达式的值,否则返回exp表达式的值。

好啦,本次使用IFIFNULL函数将NULL值映射到其他更有意义的值,以便以可读方式呈现数据的小技巧就分享到这里了。如果感觉不错的话,请多多点赞支持哦。。。

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录