`
wangyijiangshui
  • 浏览: 85978 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类

MySQL日期函数

 
阅读更多

1、在指定的日期字段上加上一个时间(包括直接的一个时间、年、月、周、日、时、分、秒等等)。

函数格式为:DATE_ADD(date,INTERVAL expr type),如:
①、在出生日期字段上加1天:DATE_ADD(出生日期,INTERVAL 1 DAY)。
②、在出生日期字段上加1周:DATE_ADD(出生日期,INTERVAL 1 WEEK)。
③、在出生日期字段上加1年:DATE_ADD(出生日期,INTERVAL 1 MONTH)。
其中type取值包括:(汉字前面是关键字,后面表示传入的数据格式)
   SECOND 秒 SECONDS 
 MINUTE 分钟 MINUTES 
 HOUR 时间 HOURS 
 DAY 天 DAYS 
 MONTH 月 MONTHS 
 YEAR 年 YEARS 
 MINUTE_SECOND 分钟和秒 "MINUTES:SECONDS" 
 HOUR_MINUTE 小时和分钟 "HOURS:MINUTES" 
 DAY_HOUR 天和小时 "DAYS HOURS" 
 YEAR_MONTH 年和月 "YEARS-MONTHS" 
 HOUR_SECOND 小时, 分钟, "HOURS:MINUTES:SECONDS" 
 DAY_MINUTE 天, 小时, 分钟 "DAYS HOURS:MINUTES" 
 DAY_SECOND 天, 小时, 分钟, 秒 "DAYS HOURS:MINUTES:SECONDS" WEEK 周 WEEKS

 

2、当前日期

 (1)、获取当前日期(年月日),使用CURDATE() 或者CURRENT_DATE,以'YYYY-MM-DD'或YYYYMMDD格式返回今天日期值,具体采用哪种格式取决于函数是在一个字符串还是数字上下文被使用。 例如:

1、SELECT CURDATE() 
//结果:2013-03-31

2、SELECT CURRENT_DATE 
//结果:2013-03-31

3、SELECT CURDATE() + 3;
//结果:20130334

 (2)获取当前时间(时分秒),使用CURTIME() 或者CURRENT_TIME ,以'HH:MM:SS'或HHMMSS格式返回当前时间值,取决于函数是在一个字符串还是在数字的上下文被使用。 

1、SELECT CURRENT_TIME ;
//结果:17:11:46

2、SELECT CURTIME();
//结果:17:12:25

3、SELECT CURTIME() + 0; 
//结果:171303

 (3)、获取当前时间(年月日时分秒),使用NOW() 或者SYSDATE() ,以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回当前的日期和时间,取决于函数是在一个字符串还是在数字的上下文被使用。

1、SELECT CURRENT_TIMESTAMP ;
//结果:2013-03-31 17:14:37

2、SELECT NOW();
//结果:2013-03-31 17:15:04

3、SELECT NOW() + 0;
//结果:20130331171517

 (4)、获取时间的秒数,使用UNIX_TIMESTAMP() 或者UNIX_TIMESTAMP(date),如果没有参数调用,返回一个Unix时间戳记(从'1970-01-01 00:00:00'GMT开始的秒数)。如果UNIX_TIMESTAMP()用一 个date参数被调用,它返回从'1970-01-01 00:00:00' GMT开始的秒数值。date可以是一个DATE字符串、一个DATETIME 字符串、一个TIMESTAMP或以YYMMDD或YYYYMMDD格式的本地时间的一个数字。

注意:当UNIX_TIMESTAMP被用于一个TIMESTAMP列,函数将直接接受值,没有隐含的“string-to-unix-timestamp”变换。

1、SELECT UNIX_TIMESTAMP();
//结果:1364721417

2、SELECT UNIX_TIMESTAMP('1997-10-04 22:23:00');
//结果:875974980

 

3、日期格式化

(1)、将数据库中datetime、date类型的数据格式化成指定的字符串格式:

DATE_FORMAT(date,format) 
根据format字符串格式化date值。下列修饰符可以被用在format字符串中: 
%M 月名字(January……December) 
%W 星期名字(Sunday……Saturday) 
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。) 
%Y 年, 数字, 4 位 
%y 年, 数字, 2 位 
%a 缩写的星期名字(Sun……Sat) 
%d 月份中的天数, 数字(00……31) 
%e 月份中的天数, 数字(0……31) 
%m 月, 数字(01……12) 
%c 月, 数字(1……12) 
%b 缩写的月份名字(Jan……Dec) 
%j 一年中的天数(001……366) 
%H 小时(00……23) 
%k 小时(0……23) 
%h 小时(01……12) 
%I 小时(01……12) 
%l 小时(1……12) 
%i 分钟, 数字(00……59) 
%r 时间,12 小时(hh:mm:ss [AP]M) 
%T 时间,24 小时(hh:mm:ss) 
%S 秒(00……59) 
%s 秒(00……59) 
%p AM或PM 
%w 一个星期中的天数(0=Sunday ……6=Saturday ) 
%U 星期(0……52), 这里星期天是星期的第一天 
%u 星期(0……52), 这里星期一是星期的第一天 
%% 一个文字“%”。 
所有的其他字符不做解释被复制到结果中。
MySQL3.23中,在格式修饰符字符前需要%。在MySQL更早的版本中,%是可选的。

 举例:

1、SELECT DATE_FORMAT(`notice_time`, '%Y-%m-%d %H:%i:%s') notice_time FROM tbl_bcall_task;
//结果:2013-03-31 16:47:14

2、select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y'); 
//结果:Saturday October 1997

3、select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s');
//结果:22:23:00

4、select DATE_FORMAT('1997-10-04 22:23:00', '%D %y %a %d %m %b %j');
//结果:4th 97 Sat 04 10 Oct 277

5、select DATE_FORMAT('1997-10-04 22:23:00', '%H %k %I %r %T %S %w');
//结果:22 22 10 10:23:00 PM 22:23:00 00 6

 (2)、如果格式化的是date类型的,格式化字符串中包含时分秒,则默认为0,例如:

SELECT DATE_FORMAT(`ttt`, '%Y-%m-%d %H:%i:%s') ttt FROM tst
//表tst中的ttt字段类型为date类型,结果:2013-03-31 00:00:00

 (3)、将秒数转换成日期,使用FROM_UNIXTIME(unix_timestamp) ,以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回unix_timestamp参数所表示的值,是函数UNIX_TIMESTAMP()的逆操作,取决于函数是在一个字符串还是或数字上下文中被使用。

1、SELECT FROM_UNIXTIME(875974980);
//结果:1997-10-04 22:23:00

2、SELECT FROM_UNIXTIME(875996580) + 0;
//结果:19971005042300

 (4)、将指定的秒数格式化成指定的日期格式(秒数标示:从'1970-01-01 00:00:00'GMT开始的秒数)。

1、SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(), '%Y %D %M %h:%i:%s %x'); 
//结果:2013 31st March 05:25:06 2013(UNIX_TIMESTAMP()表示从'1970-01-01 00:00:00'GMT开始到当前的秒数)。

2、SELECT FROM_UNIXTIME(1364721998, '%Y-%m-%d %H:%i:%s'); 
//结果:2013-03-31 17:26:38

(5)、将秒数转换成时分秒格式,变换成小时、分钟和秒,值以'HH:MM:SS'或HHMMSS格式化,取决于函数是在一个字符串还是在数字上下文中被使用。  

1、SELECT SEC_TO_TIME(4378);
//结果:01:12:58

2、SELECT SEC_TO_TIME(4378)+0;
//结果:11258

(6)、将时分秒格式的时间转换成秒数。

1、SELECT TIME_TO_SEC('22:23:00');
//结果:80580

2、SELECT TIME_TO_SEC('00:00:38'); 
//结果:38

  

 

4、时间格式化

主要用于处理日期中的时分秒一下的时间,不包括年月日部分,如果在结果中包含,则默认用0填充,例如(所用格式化修饰符与DATE_FORMAT一样):

1、SELECT TIME_FORMAT(NOW(),'%H:%i:%s') 
//结果:17:03:02

2、SELECT TIME_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s') 
//结果:SELECT TIME_FORMAT(NOW(),'%H:%i:%s') 

 

 

 

分享到:
评论

相关推荐

    MYSQL 日期函数大全

    MYSQL 日期函数大全,供大家一起共同分享学习。

    mysql日期函数

    mysql日期函数 mysql日期函数 mysql日期函数 mysql日期函数 mysql日期函数

    mysql 日期函数相关操作

    在MySQL中,日期和时间函数提供了丰富的功能,用于处理日期和时间数据,这对于数据库管理和查询极为关键。...以上只是MySQL日期函数的一部分,通过合理应用这些函数,可以极大提高数据查询和处理的效率与准确性。

    mysql日期函数时间函数及加减运算

    "MySQL 日期函数和时间函数及加减运算" MySQL 日期函数和时间函数是 MySQL 中非常重要的函数,用于处理日期和时间数据类型。这些函数可以帮助开发者快速获得当前日期和时间、执行日期和时间相关的操作。 获得当前...

    mysql日期函数总结

    ### MySQL日期函数总结 在MySQL数据库管理中,处理日期与时间是常见的需求之一。通过使用各种日期函数,我们可以实现对日期进行格式化、计算日期之间的差异等操作,从而提高数据处理效率。本文将对MySQL中常用的...

    mysql 日期函数

    ### MySQL 日期函数详解 MySQL 是一款广泛使用的开源关系型数据库管理系统,提供了丰富的日期和时间处理函数,使得在数据操作中处理日期变得简单且高效。本文将深入解析MySQL中的日期函数,包括它们的功能、语法...

    MySQL日期时间函数大全

    MySQL 日期时间函数大全 在 MySQL 中,日期时间函数是非常重要的一部分,它们可以帮助我们对日期和时间进行各种操作。下面我们将对 MySQL 中的日期时间函数进行详细的讲解。 DAYOFWEEK(date) `DAYOFWEEK` 函数...

    MySQL日期函数与日期转换格式化函数大全

    MySQL日期函数和日期转换格式化函数是数据库查询和数据分析中不可或缺的部分,它们允许开发者和数据分析师对日期和时间数据进行处理和操作。以下是一些常用的MySQL日期函数和转换函数的详细说明: 1. `DAYOFWEEK...

    mysql时间日期函数

    在MySQL数据库中,时间日期函数是处理与时间相关的数据时不可或缺的一部分。这些函数提供了丰富的功能,可以帮助用户在查询、更新或插入数据时精确地操作日期和时间。下面将详细介绍几个核心的时间日期函数及其应用...

    Mysql函数手册.rar_MySQL函数手册_VZI_mysql 函数手册

    3. 日期和时间函数:如NOW()获取当前日期和时间,DATE_FORMAT()用于格式化日期和时间,DATE_ADD()和DATE_SUB()可以对日期进行加减操作。 4. 转换函数:如CAST()和CONVERT()用于在不同数据类型间转换,以及INET_ATON...

    MySQL常用函数大全

    ### MySQL常用函数详解 ...以上总结涵盖了MySQL中常用的数学、组合、聚合、字符串以及日期时间函数。这些函数广泛应用于各种场景,例如数据处理、报表生成等。熟练掌握这些函数有助于提高SQL查询效率及结果准确性。

    mysql的日期和时间函数.rar

    通过深入学习和实践这些MySQL日期和时间函数,开发者可以更有效地管理数据库中的日期和时间数据,创建出更加精确和复杂的查询语句。这个教程文档“mysql的日期和时间函数.doc”应该包含了详细解释和实例,帮助读者更...

    MySQL常用函数

    包含了MySQL常用的所有函数及详解。IFNULL(expr1,expr2),FROM_UNIXTIME。

    MySQL时间日期相关函数

    对于开发人员来说,理解并灵活运用这些MySQL时间日期函数是至关重要的。在文档《mysql函数大全.doc》中,你应该能找到更多关于这些函数以及其他MySQL函数的详细信息和示例,帮助你进一步提升数据库操作技能。

    MySQL常用函数的举例及例子

    ### MySQL常用函数详解 #### 一、数学函数 ...以上函数覆盖了MySQL中常用的数学函数、聚合函数、字符串函数以及日期和时间函数,通过合理运用这些函数可以帮助我们更加高效地处理数据库中的数据。

    mysql中取系统当前时间,当前日期方便查询判定的代码

    获取当前时间的MySql时间函数处理MySql时间日期的函数有很多,下面为您介绍的就是用于获取当前时间的MySql时间函数,如果您对此感兴趣的话,不妨一看下面为您介绍的MySql时间函数用于获取当前时间,该MySql时间函数...

    MySQL内置函数中的日期和时间函数详解.pdf

    在MySQL中,日期和时间函数是内置函数的重要组成部分,它们提供了丰富的操作来处理日期和时间数据。本文将详细探讨这些函数,并通过示例说明如何在实际应用中使用它们。 1. CURDATE()和CURRENT_DATE() CURDATE()...

    mysql+php中文乱码问题及mysql时间函数.docx

    **MySQL日期函数总结**: MySQL提供了丰富的日期和时间函数,其中`DATE_FORMAT()`函数用于根据指定的`format`格式化日期值。以下是一些常用的格式修饰符: - `%M`:完整月份名称(January...December) - `%W`:...

Global site tag (gtag.js) - Google Analytics