V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
kennedy32
V2EX  ›  PHP

mysql 按月分组,同时输出当前组的月份

  •  
  •   kennedy32 · Jul 2, 2014 · 5897 views
    This topic created in 4321 days ago, the information mentioned may be changed or developed.
    比如按月分组分成了6月,7月,8月三组,如何输出“6月”/“7月”/“8月”这三个字符串?
    Supplement 1  ·  Jul 2, 2014
    我想到一个比较简单的实现就是提取该组任一个数据的月份,不过不知道有没有更简单的
    11 replies    2014-07-02 11:41:53 +08:00
    yangqi
        1
    yangqi  
       Jul 2, 2014
    没看懂什么意思
    Automan
        2
    Automan  
       Jul 2, 2014   ❤️ 1
    date_format(month,'%c月')
    em70
        3
    em70  
       Jul 2, 2014 via Android
    输出字符串管MySQL屁事
    Mac
        4
    Mac  
       Jul 2, 2014   ❤️ 1
    select group_concat(distinct 月份字段 SEPARATOR '/') from 表名 group by ???字段

    请详细描述你的要输出的目的和表结构。
    kennedy32
        5
    kennedy32  
    OP
       Jul 2, 2014
    @Mac 对,就是group by的字段
    kennedy32
        6
    kennedy32  
    OP
       Jul 2, 2014
    @Mac 表结构是id,date,key,value;group by date_format(time,'%Y%m');
    heliar
        7
    heliar  
       Jul 2, 2014
    你的意思是按月份输出三个列么。。
    solu
        8
    solu  
       Jul 2, 2014   ❤️ 1
    话说我一直在干这样的事
    ---------------
    ...|record_time
    ---------------
    ...|2014-06-07
    .....
    ---------------

    select left(record_time, 7) mth from table group by mth
    kennedy32
        9
    kennedy32  
    OP
       Jul 2, 2014
    @heliar 对,输出三个列之后加个月份作为表头
    kennedy32
        10
    kennedy32  
    OP
       Jul 2, 2014
    @solupro 非常感谢,这个比较接近
    zeayes
        11
    zeayes  
       Jul 2, 2014
    @kennedy32 可以用IF+GROUP BY
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   798 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 20:33 · PVG 04:33 · LAX 13:33 · JFK 16:33
    ♥ Do have faith in what you're doing.