时间戳相关操作
时间戳相关操作
格式化
DATE_FORMAT(submit_time,'%Y%m')
# Y:完整年
# y:年份的后 2 位
抓取年月日
# Write your MySQL query statement below
select transaction_id from Transactions t, (select date_format(day, '%y%m%d') `date`, max(amount) amount from Transactions
group by `date`) temp
where date_format(t.day, '%y%m%d') = temp.date and t.amount = temp.amount
order by transaction_id
日期格式(1881. 转换日期格式)
select concat(dayname(day), ', ', monthname(day), ' ', day(day), ', ', year(day)) day from Days
+-------------------------+
| day |
+-------------------------+
| Tuesday, April 12, 2022 |
| Monday, August 9, 2021 |
| Friday, June 26, 2020 |
+-------------------------+
SELECT
DATE_FORMAT(day, '%W, %M %e, %Y') AS day
FROM
days
日期差
1. TIMESTAMPDIFF
# 第二个参数 - 第一个参数
SELECT TIMESTAMPDIFF(MONTH,'2012-10-01','2013-01-13');
2. DATEDIFF
# 第一个参数 - 第二个参数
SELECT DATEDIFF('2013-01-13','2012-10-01'); # 返回相差的天数
1709. 访问日期之间的最大的空档期
# Write your MySQL query statement below
# now:2021-1-1
# 求:最大间隔
# 1. 特殊情况:最后一个,now - max
select user_id, max(date_diff) biggest_window from
(select user_id, datediff('2021-1-1', max(visit_date)) date_diff from UserVisits
group by user_id
union
select user_id, max(datediff(next, visit_date)) date_diff from
(select
user_id,
visit_date,
lead(visit_date) over(partition by user_id order by visit_date) next
from UserVisits) temp
where temp.next is not null
group by user_id) temp2
group by user_id
日期增加 DATE_ADD()
DATE_ADD() 函数向日期添加指定的时间间隔。
# 语法
# 1. date:日期表达式
# 2. expr:时间间隔
# 3. type:按照什么字段增加【SECOND、MINUTE、HOUR、DAY、WEEK、MONTH、QUARTER、YEAR】
DATE_ADD(date,INTERVAL expr type)
分类:
数据库 / Mysql
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix