MySQL 找每个月最后一个星期五 -- 函数定义与使用

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

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

在这里插入图片描述

然后问题是这样的:

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的情况)

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

思路:

  1. LAST_DAY 函数找当月最后一天 x
  2. 日期 x 逐天减少
  3. 直到 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
  • 10
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 27
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值