SQL时间问题,你会吗?(条件表达式、datediff和timestampdiff)

某店铺的商品信息表中记录了有哪些商品

订单明细表中记录了商品销售的流水;"订单明细表"中的'商品ID' 与"商品信息表"中的'商品ID'一一对应。

 业务问题:每天更新"订单明细表"里的间隔周数。计算规则是当前日期与支付时间的相隔周数(值为其中一个,1周,2周,4周,8周,16周,16周以上)  

【解题思路】

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

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

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

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

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

常用计算日期差的函数有俩datediff和timestampdiff。具体用法如下:

这里使用timestampdiff函数可以直接计算两个日期的相差周数。

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


update <表名> set <字段名> = <predicate>

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


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

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

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

【本题考点】

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值