doubi1624 2012-09-13 12:58
浏览 193
已采纳

DATE(时间戳)返回错误的月份

Here is my query:

$chart_result = mysql_query("SELECT * 
                             FROM (SELECT DATE(timestamp) AS ts, 
                                          YEAR(timestamp) AS year, 
                                          MONTH(timestamp) AS month, 
                                          DAY(timestamp) AS day, 
                                          SUM(paymentgross) AS sales 
                                   FROM stats_ans_1 
                                   GROUP BY DATE(timestamp) DESC 
                                   LIMIT 10
                                  ) AS TBL 
                             GROUP BY ts");

and here is the timestamp:

2012-09-12 19:45:23

MONTH(timestamp) is absolutely determined that the timestamp is in October not September - which is obviously wrong. Have mercy on my poor brain cells!

  • 写回答

1条回答 默认 最新

  • duandazhen7306 2012-09-13 13:06
    关注

    You can use DATE_FORMAT function to return month in string format:

    SELECT DATE_FORMAT('2012-09-12 19:45:23', '%M') AS `month`;
    

    Also you don't need to use GROUP BY twice, try this query:

    SELECT DATE(timestamp) AS ts,
           YEAR(timestamp) AS year,
           MONTH(timestamp) AS month,
           DAY(timestamp) AS day,
           SUM(paymentgross) AS sales
    FROM stats_ans_1
    GROUP BY DATE(timestamp) DESC
    LIMIT 10;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记