账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    php mysql 如何获取最近一周7天,每天的订单数?
    20
    0

    问题一:
    1、$array数组如下:

    array (size=7)
      1 => string '2018-09-21' (length=10)
      2 => string '2018-09-22' (length=10)
      3 => string '2018-09-23' (length=10)
      4 => string '2018-09-24' (length=10)
      5 => string '2018-09-25' (length=10)
      6 => string '2018-09-26' (length=10)
      7 => string '2018-09-27' (length=10)

    2、$list数组如下:

    array (size=3)
      0 => 
        array (size=2)
          'riqi' => string '2018-09-21' (length=10)
          'count' => int 2
      1 => 
        array (size=2)
          'riqi' => string '2018-09-26' (length=10)
          'count' => int 2
      2 => 
        array (size=2)
          'riqi' => string '2018-09-27' (length=10)
          'count' => int 3

    求助:如何php实现以下效果

    array (size=3)
      0 => 
        array (size=2)
          'riqi' => string '2018-09-21' (length=10)
          'count' => int 2
      1 => 
        array (size=2)
          'riqi' => string '2018-09-22' (length=10)
          'count' => int 0
      2 => 
        array (size=2)
          'riqi' => string '2018-09-23' (length=10)
          'count' => int 0
      3 => 
        array (size=2)
          'riqi' => string '2018-09-24' (length=10)
          'count' => int 0
      4 => 
        array (size=2)
          'riqi' => string '2018-09-25' (length=10)
          'count' => int 0
      5 => 
        array (size=2)
          'riqi' => string '2018-09-26' (length=10)
          'count' => int 2
      6 => 
        array (size=2)
          'riqi' => string '2018-09-27' (length=10)
          'count' => int 3

    问题二:
    现有sql如下:

    select FROM_UNIXTIME(addtime,'%Y-%m-%d') as riqi, count(1) as count from order where FROM_UNIXTIME(addtime,'%Y-%m-%d') >= now() - interval 7 day group by FROM_UNIXTIME(addtime,'%Y-%m-%d')

    如何能通过一句sql实现以下效果

    array (size=3)
      0 => 
        array (size=2)
          'riqi' => string '2018-09-21' (length=10)
          'count' => int 2
      1 => 
        array (size=2)
          'riqi' => string '2018-09-22' (length=10)
          'count' => int 0
      2 => 
        array (size=2)
          'riqi' => string '2018-09-23' (length=10)
          'count' => int 0
      3 => 
        array (size=2)
          'riqi' => string '2018-09-24' (length=10)
          'count' => int 0
      4 => 
        array (size=2)
          'riqi' => string '2018-09-25' (length=10)
          'count' => int 0
      5 => 
        array (size=2)
          'riqi' => string '2018-09-26' (length=10)
          'count' => int 2
      6 => 
        array (size=2)
          'riqi' => string '2018-09-27' (length=10)
          'count' => int 3
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • ╰︶賴床專業戶こ 普通会员 1楼

      在MySQL中,你可以使用以下SQL查询来获取最近一周的7天,每天的订单数:

      sql SELECT DATE_FORMAT(order_date, '%Y-%m-%d') as date, COUNT(*) as order_count FROM orders WHERE order_date BETWEEN DATE_SUB(NOW(), INTERVAL 7 DAY) AND NOW() GROUP BY date ORDER BY date;

      这个查询首先从订单日期列中获取日期,然后使用DATE_SUB函数在当前日期前7天,使用COUNT函数计算每天的订单数。GROUP BY语句将结果按日期分组,最后ORDER BY语句按日期排序。

      注意:这个查询假设你有一个名为"orders"的表,其中有一个名为"order_date"的列,它存储订单日期。如果你的表名或列名不同,你需要相应地修改这个查询。

      如果你的表中的订单日期是字符串,你需要使用MySQL的CONVERT函数将其转换为日期格式,然后再使用DATE_SUB和COUNT函数。例如,如果你的计数结果将为7天的每一天的订单数。

      注意:这个查询可能不会完全准确,因为它假设订单日期是有效的日期格式,而且可能没有正确地过滤掉未下单的订单。在实际使用中,你可能需要根据你的具体需求来调整这个查询。

    更多回答
    扫一扫访问手机版