周五怎么表示 mysql_MySQL 找每个月最后一个星期五 -- 函数定义与使用

数据库作业有一道题是这样子的:

有一张名叫emp的表记录员工信息,其中有如下字段 HIREDATE 表示员工被雇用的日期:

a4b007bc2a3c0670653285c6f106fbc5.png

然后问题是这样的:

q7.Show details of employee hiredates and the date of their first payday.

(Paydays occur on the last Friday of each month)

(plus their names)

意思就是每个月的最后一个周五是发工资的日子,要我们输出他们领到第一桶金的日子。(这里其实是计算当月payday,不考虑hiredate超过payday的情况)

那么怎么通过一个日期计算出当月的最后一个周五呢?我们用最暴力的方法,直接迭代计算:

思路:

LAST_DAY 函数找当月最后一天 x

日期 x 逐天减少

直到 x 等于周五,即是最后一个周五

代码:

DELIMITER $$# 结束符由 ; 改为 $$ 。因为函数中间需要用到 ; 号

DROp FUNCTION IF EXISTS last_friday $$# 删除之前定义的函数 last_friday

CREATE FUNCTION last_friday (dt DATE) RETURNS DATE# 定义函数 last_friday 有一个DATE类的形参 dt,返回DATE对象

BEGIN

DECLARE last DATE;# 临时变量 last

SET last=LAST_DAY(dt);# last=dt的最后一天

WHILE DATE_FORMAT(last, "%W")!="Friday" DO# 不断判断是否为周五

SET last=DATE_SUB(last, interval 1 day);# 迭代减少天数

END WHILE;

RETURN last;# 返回结果

END $$

DELIMITER ;# 结束符由 $$ 改为 ; 号

# 不带注释 ↓

DELIMITER $$

DROP FUNCTION IF EXISTS last_friday $$

CREATE FUNCTION last_friday (dt DATE) RETURNS DATE

BEGIN

DECLARE last DATE;

SET last=LAST_DAY(dt);

WHILE DATE_FORMAT(last, "%W")!="Friday" DO

SET last=DATE_SUB(last, interval 1 day);

END WHILE;

RETURN last;

END $$

DELIMITER ;

然后我们就可以通过 last_friday 函数进行查询:

SELECT ENAME, HIREDATE, last_friday(HIREDATE) FROM emp;

结果:

a1049aaf3d73fa0ebd9de83931891a06.png

然后下一题:

q8.Refine your answer to 7 such that it works

even if an employee is hired after the last Friday of the month

(cf Martin)

意思是有一些员工是在payday之后入职的,比如:

e690fd7492a75086afb2ce9fbfad0892.png

那么我们应该找下一个payday。思路也很简单,通过 if 语句进行判断即可。

如果当月payday大于入职日期hiredate,返回当月payday

如果当月payday小于入职日期hiredate,返回下个月的payday

我们首先编写一个函数next_friday,计算下个月的payday:

DELIMITER $$

DROP FUNCTION IF EXISTS next_friday $$

CREATE FUNCTION next_friday (dt DATE) RETURNS DATE

BEGIN

DECLARE last DATE;

SET last=LAST_DAY(DATE_ADD(dt, interval 1 month));

WHILE DATE_FORMAT(last, "%W")!="Friday" DO

SET last=DATE_SUB(last, interval 1 day);

END WHILE;

RETURN last;

END $$

DELIMITER ;

这个函数和 last_friday 没啥区别,就是计算下个月而已:

a61090eedfc2ca1f096c223b22bc209c.png

随后我们修改 last_friday ,最后返回时加一个判断即可:

DELIMITER $$

DROP FUNCTION IF EXISTS last_friday $$

CREATE FUNCTION last_friday (dt DATE) RETURNS DATE

BEGIN

DECLARE last DATE;

SET last=LAST_DAY(dt);

WHILE DATE_FORMAT(last, "%W")!="Friday" DO

SET last=DATE_SUB(last, interval 1 day);

END WHILE;

RETURN IF(last>dt, last, next_friday(dt));

END $$

DELIMITER ;

注意这个 if 表达式即可:

if(expr, case1, case2)

if(条件, 情况1, 情况2)

5d32a88155a12612bc963252e7e7878a.png

随后再次运行查询:

6a82457c1008d5290766201889dfa39e.png

舒服了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值