时间问题,你会吗?

时间问题,你会吗?
某店铺的商品信息表中记录了有哪些商品
时间问题,你会吗?
订单明细表中记录了商品销售的流水;"订单明细表"中的'商品ID' 与"商品信息表"中的'商品ID'一一对应。
时间问题,你会吗?
业务问题:每天更新"订单明细表"里的间隔周数。计算规则是当前日期与支付时间的相隔周数(值为其中一个,1周,2周,4周,8周,16周,16周以上)

【解题思路】

使用逻辑树分析方法,将问题拆解为2个子问题:

1)计算当前日期与支付时间的相隔周数

2)根据间隔周数条件分组

1.计算当前日期与支付时间的相隔周数

设计到日期,要能想到《猴子从零学会SQL》里讲过的日期函数。

常用计算日期差的函数有俩datediff和timestampdiff。具体用法如下:
时间问题,你会吗?
这里使用timestampdiff函数可以直接计算两个日期的相差周数。

而更新表,需要使用update函数,SQL语法如下

1 update <表名> set <字段名> = `js


用下面SQL就可以得到当前日期与支付时间的相隔周数

update 订单明细表
set 间隔周数 =
(timestampdiff(WEEK,支付时间,NOW()));

查询结果:

![微信图片_20211008193745.jpg](https://ucc.alicdn.com/pic/developer-ecology/aff000afcfbb4a06ac70292a87376cec.jpg)
2.根据间隔周数条件分组



可以使用case when 条件表达式,对间隔周数按条件进行分组。

1 update 订单明细表
2 set 间隔周数 =
3 (case when timestampdiff(WEEK,支付时间,NOW()) = 1 then '1周'
4 when timestampdiff(WEEK,支付时间,NOW()) = 2 then '2周'
5 when timestampdiff(WEEK,支付时间,NOW()) <= 4 then '4周'
6 when timestampdiff(WEEK,支付时间,NOW()) <= 8 then '8周'
7 when timestampdiff(WEEK,支付时间,NOW()) <= 16 then '16周'
8 else '16周以上'
9 end);

查询结果:

![微信图片_20211008193909.jpg](https://ucc.alicdn.com/pic/developer-ecology/40b4e16cf454494c809dc8b83adf90f0.jpg)
【本题考点】



1)涉及到多条件分组问题,要想到使用case when条件表达式。



2)时间问题,要想到常用的日期函数(datediff和timestampdiff)来解决。

![微信图片_20211008193937.jpg](https://ucc.alicdn.com/pic/developer-ecology/e97b8bf3449b4d2fa95a2666e8a73964.jpg)
上一篇:怎样才算精通 Excel?


下一篇:如何自己找数据分析项目来做?