小编典典

单行的总和值?

mysql

我有一个MySQL查询,该查询返回的是一行1和0。用于进度条指示器。我现在已经在代码中对其求和了,但是我尝试对查询中的值求和,并且意识到我不能使用SUM(),因为它们有很多列,但只有一行。

有没有一种方法可以自动在查询中求和?就像这样:

item_1 | item_2 | item_3 | item_4
-------+--------+--------+--------
     1 |      1 |      0 |      0

编辑:我忘了提,item_1等等不是简单的字段值,而是每个值,而是一个表达式,例如SELECT IF( field_1 = 1 and field_2 IS NOT NULL, 0, 1 ) AS item_1 ...,所以看起来我必须做一个嵌套查询:

SELECT ( item_1 + item_2 ... ) FROM ( SELECT IF( field_1 = y and field_2 IS NOT NULL, 1, 0 ) AS item_1 ... ) AS alias

正确?


阅读 273

收藏
2020-05-17

共1个答案

小编典典

select item_1 + item_2 + item_3 + item_4 as ItemSum
from MyTable

如果可以有空值,则需要按以下方式处理它们:

select ifnull(item_1, 0) + ifnull(item_2, 0) + ifnull(item_3, 0) + ifnull(item_4, 0) as ItemSum
from MyTable
2020-05-17