某店铺的商品信息表中记录了有哪些商品
订单明细表中记录了商品销售的流水;"订单明细表"中的'商品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)