【问题标题】:MySQL SELECT SUM CASE with GROUP BY or DISTINCTMySQL SELECT SUM CASE 与 GROUP BY 或 DISTINCT
【发布时间】:2021-02-09 14:30:31
【问题描述】:

我正在尝试按月计算日志表中的唯一用户 ID。到目前为止,我想出了以下查询:

SELECT 
COUNT(CASE WHEN log_date LIKE '2020-01%' THEN 1 END) AS januari
FROM user_log;

此查询返回 1 月 user_log 的所有行的总数。但是我想知道有多少 unique 用户在 Januari 中登录。所以我需要类似的东西:

SELECT 
COUNT(**DISTINCT user_id** CASE WHEN log_date LIKE '2020-01%' THEN 1 END) AS januari
FROM user_log;

我也尝试过 GROUP BY,但到目前为止没有运气。有人有什么建议吗?

【问题讨论】:

  • 使用字符串上下文测试日期是不好的做法。使用log_date BETWEEN '2020-01-01' AND '2020-01-31' - 这允许使用索引。

标签: mysql sql count case distinct


【解决方案1】:

考虑:

SELECT COUNT(DISTINCT CASE WHEN log_date >= '2020-01-01' AND log_date < '2020-02-01' THEN userid END) AS januari
FROM user_log;

我将过滤逻辑更改为使用半开间隔而不是字符串匹配:它更有效。

请注意,如果您只是一月份的结果,则使用 WHERE 子句就足够了:

SELECT COUNT(DISTINCT userid) januari
FROM user_log
WHERE log_date >= '2020-01-01' AND log_date < '2020-02-01'

【讨论】:

  • 非常感谢 GMB。你的答案很好。我也确实需要其他月份,所以第一个选项是我使用的那个。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-06-09
  • 1970-01-01
  • 2016-08-14
  • 1970-01-01
  • 2023-03-10
  • 2014-01-12
  • 2010-10-09
相关资源
最近更新 更多