MySQL:将NULL转换为0
让我们假设下面的表(例如几个内部联接语句的结果):
id | column_1 | column_2 ------------------------ 1 | 1 | 2 | 2 | 2 3 | | 3
你可以从下面的例子中得到:
- 在文本或ntext数据types上替代REPLACE
- 一个面向对象的程序员怎么能够围绕数据库驱动的编程?
- 如何find当前的交易水平?
- 如何做一个存储过程SELECT TOP @Param?
- GROUP BY组合/连接一列
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
接受任意数量的列/值并返回传递给它的第一个非空值。