MySQL:将NULL转换为0

让我们假设下面的表(例如几个内部联接语句的结果):

id | column_1 | column_2 ------------------------ 1 | 1 | 2 | 2 | 2 3 | | 3 

你可以从下面的例子中得到:

 select a.id, t1.column_1, t2.column_2 from a left join t1 on a.id = t1.id left join t2 on a.id = t2.id 

现在,如果我想总结t1.column_1和t2.column_2如下

 select a.id, t1.column_1, t2.column_2, (t1.column_1 + t2.column_2) as cumulated from a left join t1 on a.id = t1.id left join t2 on a.id = t2.id 

reslut将如下所示:

 id | column_1 | column_2 | cumulated ------------------------------------ 1 | 1 | NULL | NULL 2 | 2 | 2 | 4 3 | NULL | 3 | NULL 

我的问题基本上是:是否有一种方法来将NULL转换为0以便做一些math?

我已经尝试了CONVERT(t1.column_1, SIGNED)CAST(t1.column_1 as SIGNED) ,但是NULL保持为NULL

One Solution collect form web for “MySQL:将NULL转换为0”

使用IFNULL(column, 0)将列值转换为零。 或者,COALESCE函数也会做同样的事情,除了(1) COALESCE符合ANSI标准, IFNULL不符合,(2) COALESCE接受任意数量的列/值并返回传递给它的第一个非空值。

  • 简单的PHP分页脚本
  • 通过在不同服务器上的两个数据库中连接两个表来查询数据
  • SQL - IF EXISTS UPDATE ELSE INSERT INTO
  • 是否有可能列出数据库中的所有外键?
  • DISTINCT只有一个列
  • 标准使用'Z'而不是NULL来表示缺失的数据?
  • 在SQL中现有表中添加非空列
  • string或二进制数据将被截断。 该语句已终止
  • T-SQL和WHERE LIKE%参数%子句
  • ADOdb中的SQL注入和一般的网站安全性
  • INNER JOIN,LEFT JOIN,RIGHT JOIN和FULL JOIN有什么区别?