我必须在php中显示一些数据数据的结构是这样的
id channel_id added_by
1 1 9999
2 1 195
3 8 9999
4 1 180
5 1 195
6 8 9999
7 1 9999
8 1 195
9 8 9999
我只需要像这样显示通道id=1的总计数
channel_id total added_by
1 2 9999
1 4 -1
它的所有通道id的类似计数(由9999相加)和所有其他相加的计数都假定为(-1)
我可以像这样做
SELECT channel_id, added_by, sum(id) as total
from table
where channel_id = 1
group by channel_id ,added_by;
但它给出的结果不是我所需要的
channel_id added_by total
1 9999 2
1 195 3
1 180 1
4条答案
按热度按时间b4lqfgs41#
http://sqlfiddle.com/#!9/437406/2
3xiyfsfu2#
你可以试试这个:
kuhbmx9i3#
希望这对你有帮助。
SELECT count(*) as total, channel_id, added_by from table group by channel_id, added_by;
qacovj5a4#
使用
CASE..WHEN
表达式中,可以确定“已修改”added_by
价值,以及GROUP BY
改为使用修改后的值。也,
SUM(id)
不会给出正确的行数。它宁愿加起来id
价值观。你可以用COUNT(*)
而是要计算行数:结果
db fiddle视图