时间问题,你会吗?

简介: 【本题考点】1)涉及到多条件分组问题,要想到使用case when条件表达式。2)时间问题,要想到常用的日期函数(datediff和timestampdiff)来解决。

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

【解题思路】

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

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

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

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

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

常用计算日期差的函数有俩datediff和timestampdiff。具体用法如下:
微信图片_20211008193433.jpg
这里使用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)
相关文章
|
3月前
|
小程序
获取本月1号0时间 获取本周一的0点时间
获取本月1号0时间 获取本周一的0点时间
|
7月前
|
Unix Linux Android开发
时间问题
时间问题
87 0
别再用大小比较时间了
由于写代码习惯了基本数据类型(int/Integer、long等)大小的比较,很多人连Date的时间先后比较也用大小(>、<、>=、<=)了。
101 0
|
消息中间件 算法 Linux
什么是时间轮
什么是时间轮
306 0
建立时间与保持时间
建立时间(Set up time,简写为T s u T_{su}T su ​ )是指触发时钟沿(以上升沿为例)到达D触发器之前,要求输入信号必须已经达到稳定的时间。对应的,保持时间(Hold time,简写为T h T_hT h ​ )是指触发时钟沿到达D触发器之后,要求输入信号还需要保持必须稳定的时间。建立时间、保持时间相对于触发时钟沿的关系如图所示。输入信号在建立时间和保持时间不能发生变化,容易出现灾难。
188 0
建立时间与保持时间
|
Unix
strtotime应用(案例:给未来时间添加对应的时间)
strtotime应用(案例:给未来时间添加对应的时间)
187 0
strtotime应用(案例:给未来时间添加对应的时间)
如果时间可以倒流
今天同事问阿粉一个问题,觉得挺有意义的,在这里也问问各位读者们:如果时间可以倒流,你最想做什么呢?为什么呢? 这个问题阿粉也问了问身边的一些朋友们,下面是他们的答案,或许可以给你一些启发 朋友 A :如果时间可以倒流,我特别想要回到高中的时候,好好学习,踏踏实实的去努力,好好读书。不是那种死板教条的读书,是有计划有效率的读书,希望自己能够死不要脸一些,多向老师和同学请教问题,我可能天资不够聪慧,但是如果能够有效率一些,死不要脸一些,最起码会比现在要好得多吧
如果时间可以倒流
一些时间的处理
let BGT = $(o.beginT).val(); let EDT = $(o.endT).val(); spanAddCls(3); // 获取点击日期, let date = statis.
809 0