Jos*_*osh 7 mysql sql group-by aggregate-functions
我有下表,其中我尝试SUM,如果type ='printer',但是,我不想重复client_ids.所以我希望这样的事情:
+------+-----------+-----------+
| k_id | client_id | type |
+------+-----------+-----------+
| 1 | 100 | pc |
| 2 | 101 | printer |
| 3 | 101 | printer |
| 4 | 101 | printer |
| 5 | 102 | cellphone |
+------+-----------+-----------+
Run Code Online (Sandbox Code Playgroud)
查询:
SELECT client_id,
SUM(IF(type = 'printer', 1,0))
FROM FOO
GROUP BY type, client_id;
Run Code Online (Sandbox Code Playgroud)
结果:
+-----------+--------------------------------+
| client_id | SUM(IF(type = 'printer', 1,0)) |
+-----------+--------------------------------+
| 102 | 0 |
| 100 | 0 |
| 101 | 3 |
+-----------+--------------------------------+
Run Code Online (Sandbox Code Playgroud)
预期结果:
+-----------+--------------------------------+
| client_id | SUM(IF(type = 'printer', 1,0)) |
+-----------+--------------------------------+
| 102 | 0 |
| 100 | 0 |
| 101 | 1 |
+-----------+--------------------------------+
Run Code Online (Sandbox Code Playgroud)
使用:
SELECT x.client_id,
COUNT(DISTINCT y.type)
FROM FOO x
LEFT JOIN FOO y ON y.client_id = x.client_id
AND y.type = 'printer'
GROUP BY x.client
Run Code Online (Sandbox Code Playgroud)
如果您不需要查看零计数的行:
SELECT client_id,
COUNT(DISTINCT type)
FROM FOO
WHERE type = 'printer'
GROUP BY type, client_id;
Run Code Online (Sandbox Code Playgroud)
有三种类型的行printer. Sum将它们全部添加,然后返回3.
如果您想查看1带打印机的行,或者0其他方式,请尝试max而不是sum:
MAX(IF(type = 'printer', 1,0))
^^^
Run Code Online (Sandbox Code Playgroud)
编辑:要计算不同打印机的数量,您可以使用子查询:
SELECT client_id
, (
select count(*)
from FOO as f2
where f1.client_id = f2.client_id
and type = 'Printer'
)
FROM FOO as f1
GROUP BY
client_id
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
29722 次 |
| 最近记录: |