0

我有一个 cron 脚本,每天将活动用户总数写入一个表。我现在正在尝试生成一个简单的报告,该报告将显示每个月的“高水位线”。由于某些帐户在当月到期,因此最高数字可能不在月末。

这是我的表结构的示例

tblUserLog
-----------
record_id   INT(11)   // PRIMARY KEY
run_date    DATE      // DATE RUN
ttl_count   INT(11)   // TOTAL FOR DAY

样本数据:

record_id      run_date      ttl_count
1              2013-06-01    500
2              2013-06-10    510
3              2013-06-20    520
4              2013-06-30    515
5              2013-07-01    525
6              2013-07-10    530
7              2013-07-20    540
8              2013-07-31    550
9              2013-08-01    560

我想要返回的是:

record_id   run_date        ttl_count
3           2013-06-20      520
8           2013-07-31      550
9           2013-08-01      560

我已经尝试了两个接近的查询......

// This will give me the total for the first of the month
SELECT s.record_id, s.run_date, s.ttl_count
FROM tblStatsIndividual s
JOIN (
    SELECT record_id
    FROM tblStatsIndividual
    GROUP BY DATE_FORMAT(run_date, '%Y %m')
    HAVING MAX(ttl_count)
) s2
ON s2.record_id = s.record_id
ORDER BY run_date DESC

这将返回每个月第一天的总计,以及总计的 record_id 和正确日期。

试过这个...

SELECT record_id,max(run_date), max(ttl)
FROM (
    SELECT record_id,run_date, max(ttl_count) AS ttl
    FROM tblStatsIndividual
    GROUP BY DATE_FORMAT(run_date, '%Y %m')
) a 
GROUP BY DATE_FORMAT(run_date, '%Y %m')
ORDER BY run_date DESC

这个似乎获得了正确的“高水位线”,但它没有返回记录 ID,或者是高水位线的行的 run_date。

您如何获得最高总数的 record_id 和 run_date?

4

2 回答 2

1

就像是

Select detail.Record_ID, detail.Run_Date, detail.ttl_Count
From tblStatsIndividual detail
Inner Join
(Select Year(run_date) as Year, Month(Run_date) as Month, Max(ttl_count) as ttl
From tblStatsIndividual
Group By Year(run_date), Month(Run_date)) maximums
On maximums.Year = Year(detail.Run_date) and maximums.Month = Month(detail.Run_date)
and maximums.ttl = detail.ttl_count

应该这样做。请注意,根据您的要求,如果您在同一个月有两条记录具有相同的(并且当月最高)ttl_count,它们都将被返回。

于 2013-08-09T19:13:15.413 回答
0

根据@Tony Hopkinson 的帮助,此查询为我提供了信息。需要注意的是它显示了第一次出现 MAX 总计的 ID 和日期,因此如果总计在一个月内连续三天相同,则返回第一天的 ID。出于我的目的,最后一个 ID 会更理想,但我可以接受:

SELECT s.Record_ID, s.Run_Date, s.ttl_Count
FROM tblStatsIndividual s
INNER JOIN (
    SELECT YEAR(run_date) AS yr, MONTH(run_date) AS mon, MAX(ttl_count) AS ttl
    FROM tblStatsIndividual
    GROUP BY DATE_FORMAT(run_date, '%Y %m')
 ) maximums
 ON maximums.yr = YEAR(s.run_date) 
    AND maximums.mon = MONTH(s.run_date) 
    AND maximums.ttl = s.ttl_Count
GROUP BY ttl_count
ORDER BY run_date DESC
于 2013-08-13T16:27:43.087 回答