MySQL:Typecasting NULL为0

Pie*_*ing 73 mysql sql casting

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

id | column_1 | column_2
------------------------
 1 |  1       | 
 2 |  2       | 2
 3 |          | 3
Run Code Online (Sandbox Code Playgroud)

例如,您可以从以下语句中获取:

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
Run Code Online (Sandbox Code Playgroud)

现在,如果我想总结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
Run Code Online (Sandbox Code Playgroud)

reslut将如下所示:

id | column_1 | column_2 | cumulated
------------------------------------
 1 |  1       | NULL     | NULL
 2 |  2       | 2        | 4
 3 |  NULL    | 3        | NULL
Run Code Online (Sandbox Code Playgroud)

我的问题基本上是:有没有办法将NULL强制转换为0才能做一些数学运算?

我曾尝试CONVERT(t1.column_1, SIGNED)CAST(t1.column_1 as SIGNED),而是NULL保持一个NULL.

Dav*_*res 144

使用IFNULL(column, 0)的列值转换到零.或者,COALESCE函数将执行相同的操作,除了(1)COALESCE符合ANSI标准,IFNULL不符合,(2)COALESCE采用任意数量的列/值并返回传递给它的第一个非空值.

  • 是...所以COALESCE(column1,column2,0)将返回这些值的第一个非null.请记住,这是水平工作,而不是垂直工作.列必须属于同一个表行. (10认同)