V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kennedy32
V2EX  ›  PHP

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

  •  
  •   kennedy32 · 2014-07-02 02:39:36 +08:00 · 5531 次点击
    这是一个创建于 3830 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如按月分组分成了6月,7月,8月三组,如何输出“6月”/“7月”/“8月”这三个字符串?
    第 1 条附言  ·  2014-07-02 09:51:22 +08:00
    我想到一个比较简单的实现就是提取该组任一个数据的月份,不过不知道有没有更简单的
    11 条回复    2014-07-02 11:41:53 +08:00
    yangqi
        1
    yangqi  
       2014-07-02 02:53:14 +08:00
    没看懂什么意思
    Automan
        2
    Automan  
       2014-07-02 03:26:50 +08:00   ❤️ 1
    date_format(month,'%c月')
    em70
        3
    em70  
       2014-07-02 03:32:48 +08:00 via Android
    输出字符串管MySQL屁事
    Mac
        4
    Mac  
       2014-07-02 08:27:24 +08:00   ❤️ 1
    select group_concat(distinct 月份字段 SEPARATOR '/') from 表名 group by ???字段

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

    select left(record_time, 7) mth from table group by mth
    kennedy32
        9
    kennedy32  
    OP
       2014-07-02 10:48:31 +08:00
    @heliar 对,输出三个列之后加个月份作为表头
    kennedy32
        10
    kennedy32  
    OP
       2014-07-02 10:56:56 +08:00
    @solupro 非常感谢,这个比较接近
    zeayes
        11
    zeayes  
       2014-07-02 11:41:53 +08:00
    @kennedy32 可以用IF+GROUP BY
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2235 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 16:11 · PVG 00:11 · LAX 08:11 · JFK 11:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.