MySQL时间函数总结
创始人
2024-06-02 01:27:33
0

点击上方蓝字关注我

46e147ff337d074180a71aa142284b14.png

竹杖芒鞋轻胜马,谁怕?一蓑烟雨任平生
  1. NOW():返回当前日期和时间

SELECT NOW();

这将返回当前日期和时间的值,例如:2023-03-11 15:32:45。

  1. DATE():从日期时间值中提取日期部分:

SELECT DATE('2023-03-11 15:32:45');

这将返回日期部分的值,即:2023-03-11。

  1. TIME():从日期时间值中提取时间部分:

SELECT TIME('2023-03-11 15:32:45');

这将返回时间部分的值,即:15:32:45。

  1. YEAR():从日期时间值中提取年份部分:

SELECT YEAR('2023-03-11 15:32:45');

这将返回年份部分的值,即:2023。

  1. MONTH():从日期时间值中提取月份部分:

SELECT MONTH('2023-03-11 15:32:45');

这将返回月份部分的值,即:3。

  1. DAY():从日期时间值中提取天数部分:

SELECT DAY('2023-03-11 15:32:45');

这将返回天数部分的值,即:11。

  1. HOUR():从日期时间值中提取小时部分:

SELECT HOUR('2023-03-11 15:32:45');

这将返回小时部分的值,即:15。

  1. MINUTE():从日期时间值中提取分钟部分:

SELECT MINUTE('2023-03-11 15:32:45');

这将返回分钟部分的值,即:32。

  1. SECOND():从日期时间值中提取秒数部分:

SELECT SECOND('2023-03-11 15:32:45');

这将返回秒数部分的值,即:45。

  1.  CURDATE():返回当前日期

SELECT CURDATE();

这将当前日期,即:2023-03-11。

  1.  UNIX_TIMESTAMP():返回当前时间戳

SELECT UNIX_TIMESTAMP();

这将返回当前时间戳的值,例如:1647045165。

  1.  FROM_UNIXTIME():将时间戳转换为日期时间值

SELECT FROM_UNIXTIME(1647045165);

这将返回时间戳对应的日期时间值,例如:2023-03-11 15:39:25。

  1. DATE_FORMAT():将日期时间值格式化为指定的字符串

SELECT DATE_FORMAT('2023-03-11 15:32:45', '%Y-%m-%d %H:%i:%s');

这将返回日期时间值的格式化字符串,即:2023-03-11 15:32:45。您可以在DATE_FORMAT函数的第二个参数中指定所需的格式。

  1. TIME_FORMAT():将时间值格式化为指定的字符串格式

SELECT TIME_FORMAT('15:32:45', '%H:%i:%s');

这将返回时间值的格式化字符串,即:15:32:45。

PS:可以在TIME_FORMAT函数的第二个参数中指定所需的格式。

  1. STR_TO_DATE(): 将字符串转换为日期时间值

SELECT STR_TO_DATE('2023-03-11', '%Y-%m-%d');
这将返回字符串对应的日期时间值,即:2023-03-11。您可以在STR_TO_DATE函数的第二个参数中指定所需的格式。
  1. WEEKDAY(): 返回给定日期的星期几

SELECT WEEKDAY('2023-03-11');
这将返回给定日期的星期几的值,例如:5(表示星期六,周一为0)。
  1. DAYNAME():返回给定日期的星期几的名称

SELECT DAYNAME('2023-03-11');
这将返回给定日期的星期几的名称,即返回"Saturday"
  1. MONTHNAME(): 返回给定日期的月份的名称

SELECT MONTHNAME('2023-03-11');
这将返回给定日期的月份的名称,例如:March。
  1. YEARWEEK(): 返回给定日期的年份和周数

SELECT YEARWEEK('2023-03-11');
这将返回给定日期的年份和周数的值,例如:202310。
  1. TIMEDIFF():计算两个时间值之间的时间差

SELECT TIMEDIFF('2023-03-11 16:00:00', '2023-03-11 15:00:00');
这将返回两个时间值之间的时间差,例如:01:00:00。
  1. TIMESTAMPDIFF():计算两个日期时间值之间的时间差,以指定的时间单位返回结果

SELECT TIMESTAMPDIFF(HOUR, '2023-03-11 15:00:00', '2023-03-11 16:00:00');

这将返回两个时间值之间的小时数,即:1。

  1. UTC_DATE():返回当前UTC日期

SELECT UTC_DATE();

这将返回当前UTC日期的值,例如:2023-03-11。

  1. UTC_TIME():返回当前UTC时间

SELECT UTC_TIME();

这将返回当前UTC时间的值,例如:15:32:45。

  1. UTC_TIMESTAMP():返回当前UTC日期和时间

SELECT UTC_TIMESTAMP();
这将返回当前UTC日期和时间的值,例如:2023-03-11 07:32:45。
  1. SEC_TO_TIME():将秒数转换为时间值

SELECT SEC_TO_TIME(3600);

这将返回秒数对应的时间值,即:01:00:00。

  1. TIME_TO_SEC():将时间值转换为秒数

SELECT TIME_TO_SEC('01:00:00');
这将返回时间值对应的秒数,即:3600。
  1. LAST_DAY():获取指定时间的当月的最后一天

SELECT LAST_DAY(DATE('2023-03-11  16:00:03'));
返回的结果为“2023-03-31”
  1. ADDDATE(): 将日期加上指定的天数

SELECT ADDDATE('2023-03-11', INTERVAL 7 DAY);

这将返回日期加上7天后的值,即:2023-03-18。

  1. SUBDATE(): 将日期减去指定的天数

SELECT SUBDATE('2023-03-11', INTERVAL 7 DAY);
这将返回日期减去7天后的值,即:2023-03-04。
  1.  DATEDIFF(): 计算两个日期之间的天数差

SELECT DATEDIFF('2023-03-11', '2023-03-04');
这将返回两个日期之间的天数差,即:7。
  1. TIMEDIFF(): 计算两个时间之间的时间差

SELECT TIMEDIFF('23:59:59', '12:00:00');
这将返回两个时间之间的时间差,即:11:59:59。
  1. TIMESTAMPDIFF():计算两个日期之间的差

SELECT TIMESTAMPDIFF(DAY, '2023-03-04', '2023-03-11');
这将返回两个日期之间的天数差,即:7。可以在TIMESTAMPDIFF函数的第一个参数中指定所需的时间单位。
  1.  计算当前月份的第一天和最后一天

SELECT DATE_FORMAT(NOW(), '%Y-%m-01') AS first_day_of_month, LAST_DAY(NOW()) AS last_day_of_month;
这将返回当前月份的第一天和最后一天的值,例如:2023-03-01和2023-03-31。
  1. 计算指定月份的第一天和最后一天

SELECT DATE_FORMAT('2023-06-15', '%Y-%m-01') AS first_day_of_month, LAST_DAY('2023-06-15') AS last_day_of_month;
这将返回指定月份的第一天和最后一天的值,例如:2023-06-01和2023-06-30。
  1. 计算当前周的第一天和最后一天

SELECT DATE_FORMAT(DATE_ADD(NOW(), INTERVAL(1-DAYOFWEEK(NOW())) DAY), '%Y-%m-%d') AS first_day_of_week, DATE_FORMAT(DATE_ADD(NOW(), INTERVAL(7-DAYOFWEEK(NOW())) DAY), '%Y-%m-%d') AS last_day_of_week;
这将返回当前周的第一天和最后一天的值(默认周日为每周的第一天),例如:2023-03-05和2023-03-11。
  1. 计算指定日期所在周的第一天和最后一天:

SELECT DATE_FORMAT(DATE_ADD('2023-06-15', INTERVAL(1-DAYOFWEEK('2023-06-15')) DAY), '%Y-%m-%d') AS first_day_of_week, DATE_FORMAT(DATE_ADD('2023-06-15', INTERVAL(7-DAYOFWEEK('2023-06-15')) DAY), '%Y-%m-%d') AS last_day_of_week;
这将返回指定日期所在周的第一天和最后一天的值,例如:2023-06-11和2023-06-17。

15a05de79e6919eebed633c0302a2502.png

往期精彩回顾

1.  MySQL高可用之MHA集群部署

2.  mysql8.0新增用户及加密规则修改的那些事

3.  比hive快10倍的大数据查询利器-- presto

4.  监控利器出鞘:Prometheus+Grafana监控MySQL、Redis数据库

5.  PostgreSQL主从复制--物理复制

6.  MySQL传统点位复制在线转为GTID模式复制

7.  MySQL敏感数据加密及解密

8.  MySQL数据备份及还原(一)

9.  MySQL数据备份及还原(二)

47057d65707b9d7a822892861c7f72d2.png

扫码关注     

1635388e7f1b93629abece27b71bf43a.jpeg

46daa986abdbba8f5c9a95786210f013.png

5f35f6ce9665dc0ce78baefb14f31777.png

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...