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

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

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

17ad9ce776e3b0fbedc8dec709152cf1.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࿰

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值