0

0

PHP日期查询函数实用代码

php中文网

php中文网

发布时间:2016-07-25 08:54:10

|

1569人浏览过

|

来源于php中文网

原创

  1. date_default_timezone_set('prc'); //默认时区

  2. echo "今天:",date("y-m-d",time()),"
    ";
  3. echo "今天:",date("y-m-d",strtotime("18 june 2008")),"
    ";
  4. echo "昨天:",date("y-m-d",strtotime("-1 day")), "
    ";
  5. echo "明天:",date("y-m-d",strtotime("+1 day")), "
    ";
  6. echo "一周后:",date("y-m-d",strtotime("+1 week")), "
    ";
  7. echo "一周零两天四小时两秒后:",date("y-m-d g:h:s",strtotime("+1 week 2 days 4 hours 2 seconds")), "
    ";
  8. echo "下个星期四:",date("y-m-d",strtotime("next thursday")), "
    ";
  9. echo "上个周一:".date("y-m-d",strtotime("last monday"))."
    ";
  10. echo "一个月前:".date("y-m-d",strtotime("last month"))."
    ";
  11. echo "一个月后:".date("y-m-d",strtotime("+1 month"))."
    ";
  12. echo "十年后:".date("y-m-d",strtotime("+10 year"))."
    ";
  13. $a = date("w",time()); //获取今天是本周 周几
  14. $startweekdate =date("y-m-d h:i:s",strtotime($today)-($a-1)*24*3600); //获取本周周一
  15. $endweekdate =date("y-m-d h:i:s",strtotime($today)+(7-$a+1)*24*3600); //获取本周最后一天 并且为下周的第一天
  16. $endnextweekdate=date("y-m-d",strtotime($endweekdate)+7*24*3600);//下下周的最后一天
  17. ?>
  18. $d = time(); //待处理的日期
  19. $w = date("w",$d); //这天是星期几

  20. $d0 = date("Y-m-d",strtotime("-$w day",$d)); //周开始
  21. $d6 = date("Y-m-d",strtotime((6-$w)." day",$d)); //周结束
  22. ?>
  23. $d = time(); //待处理的日期
  24. $w = date("w",$d); //这天是星期几
  25. $d0 = mktime (0,0,0,date("m"),date("d") - $w,date("Y"));//周开始

  26. $d0 = mktime (0,0,0,date("m"),date("d") - $w + 6,date("Y"));//周结束
  27. ?>
  28. $date = time();
  29. $w = date("w",$d);

  30. $d0 = date("Y-m-d",strtotime("-$w day",$date)); //周开始
  31. $d6 = date("Y-m-d",strtotime((6-$w)." day",$date)); //周结束
  32. ?>
  33. $date1 = date("Y-m-d",strtotime("Sunday")); //周开始
  34. $date2 = date("Y-m-d",strtotime("Saturday")); //周结束
  35. $date1 = date("Y-m-d",strtotime("last Sunday")); //上周开始
  36. $date2 = date("Y-m-d",strtotime("last Saturday")); //上周结束
  37. //得到系统的年月
  38. $tmp_date=date("Ym");
  39. //切割出年份
  40. $tmp_year=substr($tmp_date,0,4);
  41. //切割出月份
  42. $tmp_mon =substr($tmp_date,4,2);
  43. $tmp_nextmnoth=mktime(0,0,0,$tmp_mon+1,1,$tmp_year);
  44. $tmp_forwardmnoth=mktime(0,0,0,$tmp_mon-1,1,$tmp_year);
  45. //得到当前月的下一个月
  46. $fm_next_mnoth=date("Ym",$tmp_nextmonth);
  47. //得到当前月的上一个月
  48. $fm_forward_mnoth=date("Ym",$tmp_forwardmonth);
  49. ?>
  50. $d=array("日","一","二","三","四","五","六");
  51. $whatday="星期".$d[date("w",strtotime($today))]; //获取今天星期几
  52. $time = abs((strtotime("2008-12-25") - strtotime(date("Y-m-d")))/86400);/获取两个日期之间的天数差
  53. ?>
复制代码

对于每个类型拥有的值范围以及并且指定日期何时间值的有效格式的描述见7.3.6 日期和时间类型。

立即学习PHP免费学习笔记(深入)”;

Khroma
Khroma

AI调色盘生成工具

下载

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

  1. mysql> SELECT something FROM table
  2. WHERE TO_DAYS(NOW()) - TO_DAYS(date_col)
复制代码

DAYOFWEEK(date) 返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。

  1. mysql> select DAYOFWEEK('1998-02-03');
  2. -> 3
复制代码

WEEKDAY(date) 返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。

  1. mysql> select WEEKDAY('1997-10-04 22:23:00');
  2. -> 5
  3. mysql> select WEEKDAY('1997-11-05');
  4. -> 2
复制代码

DAYOFMONTH(date) 返回date的月份中日期,在1到31范围内。

  1. mysql> select DAYOFMONTH('1998-02-03');
  2. -> 3
复制代码

DAYOFYEAR(date) 返回date在一年中的日数, 在1到366范围内。

  1. mysql> select DAYOFYEAR('1998-02-03');
  2. -> 34
复制代码

MONTH(date) 返回date的月份,范围1到12。

  1. mysql> select MONTH('1998-02-03');
  2. -> 2
复制代码

DAYNAME(date) 返回date的星期名字。

  1. mysql> select DAYNAME("1998-02-05");
  2. -> 'Thursday'
复制代码

MONTHNAME(date) 返回date的月份名字。

  1. mysql> select MONTHNAME("1998-02-05");
  2. -> 'February'
复制代码

QUARTER(date) 返回date一年中的季度,范围1到4。

  1. mysql> select QUARTER('98-04-01');
  2. -> 2
复制代码

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

  1. mysql> select WEEK('1998-02-20');
  2. -> 7
  3. mysql> select WEEK('1998-02-20',0);
  4. -> 7
  5. mysql> select WEEK('1998-02-20',1);
  6. -> 8
复制代码

YEAR(date) 返回date的年份,范围在1000到9999。

  1. mysql> select YEAR('98-02-03');
  2. -> 1998
复制代码

HOUR(time) 返回time的小时,范围是0到23。

  1. mysql> select HOUR('10:05:03');
  2. -> 10
复制代码

MINUTE(time) 返回time的分钟,范围是0到59。

  1. mysql> select MINUTE('98-02-03 10:05:03');
  2. -> 5
复制代码

SECOND(time) 回来time的秒数,范围是0到59。

  1. mysql> select SECOND('10:05:03');
  2. -> 3
复制代码

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

  1. mysql> select PERIOD_ADD(9801,2);
  2. -> 199803
复制代码

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

  1. mysql> select PERIOD_DIFF(9802,199703);
  2. -> 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 分钟和秒 "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"

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

  1. mysql> SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND;
  2. -> 1998-01-01 00:00:00
  3. mysql> SELECT INTERVAL 1 DAY + "1997-12-31";
  4. -> 1998-01-01
  5. mysql> SELECT "1998-01-01" - INTERVAL 1 SECOND;
  6. -> 1997-12-31 23:59:59
  7. mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
  8. INTERVAL 1 SECOND);
  9. -> 1998-01-01 00:00:00
  10. mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
  11. INTERVAL 1 DAY);
  12. -> 1998-01-01 23:59:59
  13. mysql> SELECT DATE_ADD("1997-12-31 23:59:59",
  14. INTERVAL "1:1" MINUTE_SECOND);
  15. -> 1998-01-01 00:01:00
  16. mysql> SELECT DATE_SUB("1998-01-01 00:00:00",
  17. INTERVAL "1 1:1:1" DAY_SECOND);
  18. -> 1997-12-30 22:58:59
  19. mysql> SELECT DATE_ADD("1998-01-01 00:00:00",
  20. INTERVAL "-1 10" DAY_HOUR);
  21. -> 1997-12-30 14:00:00
  22. mysql> SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY);
  23. -> 1997-12-02
  24. mysql> SELECT EXTRACT(YEAR FROM "1999-07-02");
  25. -> 1999
  26. mysql> SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03");
  27. -> 199907
  28. mysql> SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03");
  29. -> 20102
复制代码

如果你指定太短的间隔值(不包括type关键词期望的间隔部分),MySQL假设你省掉了间隔值的最左面部分。例如, 如果你指定一个type是DAY_SECOND,值expr被希望有天、小时、分钟和秒部分。如果你象"1:10"这样指定值, MySQL假设日子和小时部分是丢失的并且值代表分钟和秒。换句话说,"1:10" DAY_SECOND以它等价于"1:10" MINUTE_SECOND 的方式解释,这对那MySQL解释TIME值表示经过的时间而非作为一天的时间的方式有二义性。如果你使用确实不正确的日期, 结果是NULL。如果你增加MONTH、YEAR_MONTH或YEAR并且结果日期大于新月份的最大值天数,日子在新月用最大的天调整。

  1. mysql> select DATE_ADD('1998-01-30', Interval 1 month);
  2. -> 1998-02-28
复制代码

注意,从前面的例子中词INTERVAL和type关键词不是区分大小写的。 TO_DAYS(date) 给出一个日期date,返回一个天数(从0年的天数)。

  1. mysql> select TO_DAYS(950501);
  2. -> 728779
  3. mysql> select TO_DAYS('1997-10-07');
  4. -> 729669
复制代码

TO_DAYS()不打算用于使用格列高里历(1582)出现前的值。

FROM_DAYS(N) 给出一个天数N,返回一个DATE值。

  1. mysql> select FROM_DAYS(729669);
  2. -> '1997-10-07'
复制代码

TO_DAYS()不打算用于使用格列高里历(1582)出现前的值。

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), 这里星期一是星期的第一天 %% 一个文字“%”。

所有的其他字符不做解释被复制到结果中。

  1. mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y');
  2. -> 'Saturday October 1997'
  3. mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s');
  4. -> '22:23:00'
  5. mysql> select DATE_FORMAT('1997-10-04 22:23:00',
  6. '%D %y %a %d %m %b %j');
  7. -> '4th 97 Sat 04 10 Oct 277'
  8. mysql> select DATE_FORMAT('1997-10-04 22:23:00',
  9. '%H %k %I %r %T %S %w');
  10. -> '22 22 10 10:23:00 PM 22:23:00 00 6'
复制代码

MySQL3.23中,在格式修饰符字符前需要%。在MySQL更早的版本中,%是可选的。

TIME_FORMAT(time,format) 这象上面的DATE_FORMAT()函数一样使用,但是format字符串只能包含处理小时、分钟和秒的那些格式修饰符。 其他修饰符产生一个NULL值或0。 CURDATE()   CURRENT_DATE 以'YYYY-MM-DD'或YYYYMMDD格式返回今天日期值,取决于函数是在一个字符串还是数字上下文被使用。

  1. mysql> select CURDATE();
  2. -> '1997-12-15'
  3. mysql> select CURDATE() + 0;
  4. -> 19971215
复制代码

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

  1. mysql> select CURTIME();
  2. -> '23:50:26'
  3. mysql> select CURTIME() + 0;
  4. -> 235026
复制代码

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

  1. mysql> select NOW();
  2. -> '1997-12-15 23:50:26'
  3. mysql> select NOW() + 0;
  4. -> 19971215235026
复制代码

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格式的本地时间的一个数字。 mysql> select UNIX_TIMESTAMP();

  1. -> 882226357
  2. mysql> select UNIX_TIMESTAMP('1997-10-04 22:23:00');
  3. -> 875996580
复制代码

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

FROM_UNIXTIME(unix_timestamp) 以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回unix_timestamp参数所表示的值,取决于函数是在一个字符串 还是或数字上下文中被使用。

  1. mysql> select FROM_UNIXTIME(875996580);
  2. -> '1997-10-04 22:23:00'
  3. mysql> select FROM_UNIXTIME(875996580) + 0;
  4. -> 19971004222300
复制代码

FROM_UNIXTIME(unix_timestamp,format) 返回表示 Unix 时间标记的一个字符串,根据format字符串格式化。format可以包含与DATE_FORMAT()函数列出的条 目同样的修饰符。

  1. mysql> select FROM_UNIXTIME(UNIX_TIMESTAMP(),
  2. '%Y %D %M %h:%i:%s %x');
  3. -> '1997 23rd December 03:43:30 x'
复制代码

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

  1. mysql> select SEC_TO_TIME(2378);
  2. -> '00:39:38'
  3. mysql> select SEC_TO_TIME(2378) + 0;
  4. -> 3938
复制代码

TIME_TO_SEC(time) 返回time参数,转换成秒。

  1. mysql> select TIME_TO_SEC('22:23:00');
  2. -> 80580
  3. mysql> select TIME_TO_SEC('00:39:38');
  4. -> 2378
复制代码


PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

89

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

276

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

59

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

99

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

105

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

230

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

619

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

173

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号