作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我使用这个查询来计算我的数据库中的身份验证错误的数量:
SELECT (
SELECT COUNT(audit.server_response_code)
FROM audit Where audit.server_response_code = '401'
) AS Locked,
(
SELECT COUNT(audit.server_response_code)
FROM audit Where audit.server_response_code = '403'
) AS unlocked,
(
SELECT COUNT(audit.server_response_code)
FROM audit Where audit.server_response_code = '490'
) AS Passforget,
(
Select Count (audit.server_response_code)
From audit where audit.server_response_code = '491'
) AS invalid
查询工作正常,但我想添加一个适用于四个语句的聚合 where 语句。我该怎么做?
最佳答案
使用case
表达式进行条件计数:
select count(case when audit.server_response_code = '401' then 1 end) AS Locked,
count(case when audit.server_response_code = '403' then 1 end) AS unlocked,
count(case when audit.server_response_code = '490' then 1 end) AS Passforget,
count(case when audit.server_response_code = '491' then 1 end) AS invalid
from audit
where audit.server_response_code in ('401','403','490','491')
可能不需要 WHERE
子句,但可能会加快处理速度(取决于数据和索引。)
更新:根据要求“我想添加一个汇总所有计数的总和列,但它现在可以工作了,我该怎么做?”
select count(case when audit.server_response_code = '401' then 1 end) AS Locked,
count(case when audit.server_response_code = '403' then 1 end) AS unlocked,
count(case when audit.server_response_code = '490' then 1 end) AS Passforget,
count(case when audit.server_response_code = '491' then 1 end) AS invalid,
count(*) as total_count
from audit
where audit.server_response_code in ('401','403','490','491')
关于sql - 在多个选择查询sql上聚合Where,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40723024/
我是一名优秀的程序员,十分优秀!