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