我有一个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 ...,所以看起来我必须做一个嵌套查询:
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
正确?
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