MySQL Nested Select Query?

后端 未结 1 1608
孤城傲影
孤城傲影 2020-12-08 13:42

Ok, so I have the following query:

SELECT MIN(`date`), `player_name`
FROM `player_playtime`
GROUP BY `player_name`

I then need to use this

相关标签:
1条回答
  • 2020-12-08 14:10

    You just need to write the first query as a subquery (derived table), inside parentheses, pick an alias for it (t below) and alias the columns as well.

    The DISTINCT can also be safely removed as the internal GROUP BY makes it redundant:

    SELECT DATE(`date`) AS `date` , COUNT(`player_name`) AS `player_count`
    FROM (
        SELECT MIN(`date`) AS `date`, `player_name`
        FROM `player_playtime`
        GROUP BY `player_name`
    ) AS t
    GROUP BY DATE( `date`) DESC LIMIT 60 ;
    

    Since the COUNT is now obvious that is only counting rows of the derived table, you can replace it with COUNT(*) and further simplify the query:

    SELECT t.date , COUNT(*) AS player_count
    FROM (
        SELECT DATE(MIN(`date`)) AS date
        FROM player_playtime
        GROUP BY player_name
    ) AS t
    GROUP BY t.date DESC LIMIT 60 ;
    
    0 讨论(0)
提交回复
热议问题