首页 数据库 mysql教程 mysql时间日期用法总结

mysql时间日期用法总结

Jun 07, 2016 pm 05:51 PM
时间日期

本文章详细的介绍mysql中时间日期的各种用法以及时间日期的各种常用方法,有需要了解的朋友可以简单的参考一下下哈。

1获得当前日期 时间(date time)1.1    函数:now()

 相关函数:current_timestamp(),localtime(),localtimestamp()

2. 获得当前日期(date)

 函数:curdate()

 相关函数:current_date(),current_date

 3. 获得当前时间(time)

函数:curtime()

 相关函数:current_time(),current_time


 
4. MySQL dayof…

函数:dayofweek(), dayofmonth(), dayofyear()分别返回日期参数,在一周、一月、一年中的位置。

举例说明

set @dt = '2008-08-08';

select dayofweek(@dt); -- 6

select dayofmonth(@dt); -- 8

select dayofyear(@dt); -- 221

日期‘2008-08-08′ 是一周中的第6 天(1 = Sunday, 2 = Monday, …, 7 = Saturday)

一月中的第8 天;一年中的第221 天

MySQL 获得当前日期时间 函数
1.1 获得当前日期 时间(date time)函数:now()

mysql> select now();

---------------------
| now()               |
---------------------
| 2008-08-08 22:20:46 |
--------------------- 除了 now() 函数能获得当前的日期时间外,MySQL 中还有下面的函数:

current_timestamp()
,current_timestamp
,localtime()
,localtime
,localtimestamp    -- (v4.0.6)
,localtimestamp()  -- (v4.0.6)这些日期时间函数,都等同于 now()。鉴于 now() 函数简短易记,建议总是使用 now() 来替代上面列出的函数。

1.2 获得当前日期 时间(date time)函数:sysdate()

sysdate() 日期时间函数跟 now() 类似,不同之处在于:now() 在执行开始时值就得到了, sysdate() 在函数执行时动态得到值。看下面的例子就明白了:

mysql> select now(), sleep(3), now();

--------------------- ---------- ---------------------
| now()               | sleep(3) | now()               |
--------------------- ---------- ---------------------
| 2008-08-08 22:28:21 |        0 | 2008-08-08 22:28:21 |
--------------------- ---------- --------------------- mysql> select sysdate(), sleep(3), sysdate();

--------------------- ---------- ---------------------
| sysdate()           | sleep(3) | sysdate()           |
--------------------- ---------- ---------------------
| 2008-08-08 22:28:41 |        0 | 2008-08-08 22:28:44 |
--------------------- ---------- --------------------- 可以看到,虽然中途 sleep 3 秒,但 now() 函数两次的时间值是相同的; sysdate() 函数两次得到的时间值相差 3 秒。MySQL Manual 中是这样描述 sysdate() 的:Return the time at which the function executes。

sysdate() 日期时间函数,一般情况下很少用到。

2. 获得当前日期(date)函数:curdate()

mysql> select curdate();

------------
| curdate()  |
------------
| 2008-08-08 |
------------ 其中,下面的两个日期函数等同于 curdate():

current_date()
,current_date3. 获得当前时间(time)函数:curtime()

mysql> select curtime();

-----------
| curtime() |
-----------
| 22:41:30  |
----------- 其中,下面的两个时间函数等同于 curtime():

current_time()
,current_time4. 获得当前 UTC 日期时间函数:utc_date(), utc_time(), utc_timestamp()

mysql> select utc_timestamp(), utc_date(), utc_time(), now()

--------------------- ------------ ------------ ---------------------
| utc_timestamp()     | utc_date() | utc_time() | now()               |
--------------------- ------------ ------------ ---------------------
| 2008-08-08 14:47:11 | 2008-08-08 | 14:47:11   | 2008-08-08 22:47:11 |
--------------------- ------------ ------------ --------------------- 因为我国位于东八时区,所以本地时间 = UTC 时间 8 小时。UTC 时间在业务涉及多个国家和地区的时候,非常有用。

网上搜集转载,方便查阅(最好的当然是的函数查询)

这里是一个使用日期函数的例子。下面的查询选择了所有记录,其date_col的值是在最后30天以内:

mysql SELECT something FROM table
WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) = 30;

DAYOFWEEK(date)
返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。
mysql select DAYOFWEEK(''''1998-02-03'''');
- 3

WEEKDAY(date)
返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。
mysql select WEEKDAY(''''1997-10-04 222300'''');
- 5
mysql select WEEKDAY(''''1997-11-05'''');
- 2

DAYOFMONTH(date)
返回date的月份中日期,在1到31范围内。
mysql select DAYOFMONTH(''''1998-02-03'''');
- 3

DAYOFYEAR(date)
返回date在一年中的日数, 在1到366范围内。
mysql select DAYOFYEAR(''''1998-02-03'''');
- 34

MONTH(date)
返回date的月份,范围1到12。
mysql select MONTH(''''1998-02-03'''');
- 2

DAYNAME(date)
返回date的星期名字。
mysql select DAYNAME(1998-02-05);
- ''''Thursday''''

MONTHNAME(date)
返回date的月份名字。
mysql select MONTHNAME(1998-02-05);
- ''''February''''

QUARTER(date)
返回date一年中的季度,范围1到4。
mysql select QUARTER(''''98-04-01'''');
- 2

WEEK(date)
 
WEEK(date,first)
对于星期天是一周的第一天的地方,有一个单个参数,返回date的周数,范围在0到52。2个参数形式WEEK()允许
你指定星期是否开始于星期天或星期一。如果第二个参数是0,星期从星期天开始,如果第二个参数是1,
从星期一开始。
mysql select WEEK(''''1998-02-20'''');
- 7
mysql select WEEK(''''1998-02-20'''',0);
- 7
mysql select WEEK(''''1998-02-20'''',1);
- 8

YEAR(date)
返回date的年份,范围在1000到9999。
mysql select YEAR(''''98-02-03'''');
- 1998

HOUR(time)
返回time的小时,范围是0到23。
mysql select HOUR(''''100503'''');
- 10

MINUTE(time)
返回time的分钟,范围是0到59。
mysql select MINUTE(''''98-02-03 100503'''');
- 5

SECOND(time)
回来time的秒数,范围是0到59。
mysql select SECOND(''''100503'''');
- 3

PERIOD_ADD(P,N)
增加N个月到阶段P(以格式YYMM或YYYYMM)。以格式YYYYMM返回值。注意阶段参数P不是日期值。
mysql select PERIOD_ADD(9801,2);
- 199803

PERIOD_DIFF(P1,P2)
返回在时期P1和P2之间月数,P1和P2应该以格式YYMM或YYYYMM。注意,时期参数P1和P2不是日期值。
mysql select PERIOD_DIFF(9802,199703);
- 11

DATE_ADD(date,INTERVAL expr type)
 
DATE_SUB(date,INTERVAL expr type)
 
ADDDATE(date,INTERVAL expr type)
 
SUBDATE(date,INTERVAL expr type)
这些功能执行日期运算。对于MySQL 3.22,他们是新的。ADDDATE()和SUBDATE()是DATE_ADD()和DATE_SUB()的同义词。
在MySQL 3.23中,你可以使用 和-而不是DATE_ADD()和DATE_SUB()。(见例子)date是一个指定开始日期的
DATETIME或DATE值,expr是指定加到开始日期或从开始日期减去的间隔值一个表达式,expr是一个字符串;它可以以
一个“-”开始表示负间隔。type是一个关键词,指明表达式应该如何被解释。EXTRACT(type FROM date)函数从日期
中返回“type”间隔。下表显示了type和expr参数怎样被关联: type值 含义 期望的expr格式
SECOND 秒 SECONDS
MINUTE 分钟 MINUTES
HOUR 时间 HOURS
DAY 天 DAYS
MONTH 月 MONTHS
YEAR 年 YEARS
MINUTE_SECOND 分钟和秒 MINUTESSECONDS
HOUR_MINUTE 小时和分钟 HOURSMINUTES
DAY_HOUR 天和小时 DAYS HOURS
YEAR_MONTH 年和月 YEARS-MONTHS
HOUR_SECOND 小时, 分钟, HOURSMINUTESSECONDS
DAY_MINUTE 天, 小时, 分钟 DAYS HOURSMINUTES
DAY_SECOND 天, 小时, 分钟, 秒 DAYS HOURSMINUTESSECONDS

MySQL在expr格式中允许任何标点分隔符。表示显示的是建议的分隔符。如果date参数是一个DATE值并且你的计算仅仅
包含YEAR、MONTH和DAY部分(即,没有时间部分),结果是一个DATE值。否则结果是一个DATETIME值。

mysql 选择 1997-12-31 235959 间隔 1 秒;
- 1998-01-01 000000
mysql 选择间隔 1 天 1997-12-31;
- 1998-01-01
mysql 选择 1998-01-01 - 间隔 1 秒;
- 1997-12-31 235959
mysql SELECT DATE_ADD(1997-12-31 235959,
间隔 1 秒);
- 1998-01-01 000000
mysql SELECT DATE_ADD(1997-12-31 235959,
间隔 1 天);
- 1998-01-01 235959
mysql SELECT DATE_ADD(1997-12-31 235959,
间隔 11 分钟_秒);
- 1998-01-01 000100
mysql SELECT DATE_SUB(1998-01-01 000000,
间隔 1 111 DAY_SECOND);
- 1997-12-30 225859
mysql SELECT DATE_ADD(1998-01-01 000000,
间隔 -1 10 DAY_HOUR);
- 1997-12-30 140000
mysql SELECT DATE_SUB(1998-01-02, INTERVAL 31 DAY);
- 1997-12-02
mysql 选择提取(年份从 1999-07-02);
- 1999
mysql 选择提取(YEAR_MONTH FROM 1999-07-02 010203);
- 199907
mysql 选择提取(DAY_MINUTE FROM 1999-07-02 010203);
- 20102

如果你指定太短的间隔值(不包括类型关键词期望的间隔部分),MySQL 假设你省掉了间隔值的最左面部分

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用Alter Table语句在MySQL中更改表? 如何使用Alter Table语句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

如何为MySQL连接配置SSL/TLS加密? 如何为MySQL连接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

您如何处理MySQL中的大型数据集? 您如何处理MySQL中的大型数据集? Mar 21, 2025 pm 12:15 PM

文章讨论了处理MySQL中大型数据集的策略,包括分区,碎片,索引和查询优化。

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? Mar 21, 2025 pm 06:28 PM

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

如何使用Drop Table语句将表放入MySQL中? 如何使用Drop Table语句将表放入MySQL中? Mar 19, 2025 pm 03:52 PM

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

如何在JSON列上创建索引? 如何在JSON列上创建索引? Mar 21, 2025 pm 12:13 PM

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

您如何用外国钥匙代表关系? 您如何用外国钥匙代表关系? Mar 19, 2025 pm 03:48 PM

文章讨论了使用外国密钥来代表数据库中的关系,重点是最佳实践,数据完整性和避免的常见陷阱。

说明InnoDB全文搜索功能。 说明InnoDB全文搜索功能。 Apr 02, 2025 pm 06:09 PM

InnoDB的全文搜索功能非常强大,能够显着提高数据库查询效率和处理大量文本数据的能力。 1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。 2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。 3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

See all articles