在php和MySql中计算时间差的方法详解


Posted in PHP onMarch 27, 2015

在php中计算时间差有时候是件麻烦的事!不过只要你掌握了日期时间函数的用法那这些也就变的简单了。

最近在研究自己爱围脖的时候就要计算到恋爱天数,这需要php根据每天的日期进行计算,下面就来谈谈实现这种日期计算的几种方法:

(1) 如果有数据库就很容易了!若是MSSQL可以使用触发器!用专门计算日期差的函数datediff()便可!若是MYSQL那就用两个日期字段的差值计算的计算结果保存在另一个数值型字段中!用时调用便可!

(2)如果没有数据库,那就得完全用php的时间日期函数!

下面主要说明之:

例:计算1998年5月3日到1999-6-5的天数:

$startdate=mktime("0","0","0","5","3","1998"); $enddate=mktime("0","0","0","6","5","1999"); //所得到的值为从1970-1-1到参数时间的总秒数结果是整数.那么下面的代码就好编多了

$days=round(($enddate-$startdate)/3600/24) ;

echo $days;

其中$days为得到的天数;

若mktime()中的参数缺省,那表示使用当前日期,这样便可计算从借书日期至今的天数。

最后说一下SQL的计算方法:

DateDiff 函数

描述:返回两个日期之间的时间间隔。

语法:

DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear>)
interval: 必选。字符串表达式,表示用于计算 date1 和 date2 之间的时间间隔。有关数值,请参阅“设置”部分。

date1, date2: 必选。日期表达式。用于计算的两个日期。

firstdayofweek: 可选。指定星期中第一天的常数。如果没有指定,则默认为星期日。有关数值,请参阅“设置”部分。

firstweekofyear: 可选。指定一年中第一周的常数。如果没有指定,则默认为 1 月 1 日所在的星期。有关数值,请参阅“设置”部分。

interval 参数可以有以下值:

yyyy (年)
q (季度)
m (月)
y (一年的日数)
d (日)
w (一周的日数)
ww (周)
h (小时)
n (分钟)
s (秒)
firstdayofweek 参数可以有以下值:

(以下分别为:常数 值 描述)

vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbSunday 1 星期日(默认)
vbMonday 2 星期一
vbTuesday 3 星期二
vbWednesday 4 星期三
vbThursday 5 星期四
vbFriday 6 星期五
vbSaturday 7 星期六
firstweekofyear 参数可以有以下值:

(以下分别为:常数 值 描述)

vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbFirstJan1 1 由 1 月 1 日所在的星期开始(默认)。
vbFirstFourDays 2 由在新年中至少有四天的第一周开始。
vbFirstFullWeek 3 由在新的一年中第一个完整的周开始。
说明:DateDiff 函数用于判断在两个日期之间存在的指定时间间隔的数目。

例如可以使用 DateDiff 计算两个日期相差的天数,或者当天到当年最后一天之间的星期数。

要计算 date1 和 date2 相差的天数,可以使用“一年的日数”(“y”)或“日”(“d”)。当 interval 为“一周的日数”(“w”)时,DateDiff 返回两个日期之间的星期数。

如果 date1 是星期一,则 DateDiff 计算到 date2 之前星期一的数目。此结果包含 date2 而不包含 date1。

如果 interval 是“周”(“ww”),则 DateDiff 函数返回日历表中两个日期之间的星期数。函数计算 date1 和 date2 之间星期日的数目。

如果 date2 是星期日,DateDiff 将计算 date2,但即使 date1 是星期日,也不会计算 date1。

如果 date1 晚于 date2,则 DateDiff 函数返回负数。 firstdayofweek 参数会对使用“w”和“ww”间隔符号的计算产生影响。

如果 date1 或 date2 是日期文字,则指定的年度会成为日期的固定部分。但是如果 date1 或 date2 被包括在引号 (“ ”) 中并且省略年份,则在代码中每次计算 date1 或 date2 表达式时,将插入当前年份。这样就可以编写适用于不同年份的程序代码。

在 interval 为“年”(“yyyy”)时,比较 12 月 31 日和来年的 1 月 1 日,虽然实际上只相差一天,DateDiff 返回 1 表示相差一个年份。

DatePart 函数

描述:返回给定日期的指定部分。 语法:

DatePart(interval, date[, firstdayofweek[, firstweekofyear>)
DatePart: 函数的语法有以下参数:
interval: 必选。字符串表达式,表示要返回的时间间隔。有关数值,请参阅“设置”部分。
date: 必选。要计算的日期表达式。
firstdayofweek: 可选。指定星期中的第一天的常数。如果没有指定,则默认为星期日。有关数值,请参阅“设置”部分。
firstweekofyear: 可选。指定一年中第一周的常数。如果没有指定,则默认为 1 月 1 日所在的星期。有关数值,请参阅“设置”部分。
其中interval 参数可以有以下值: yyyy (年) 、q (季度) 、m (月) 、y (一年的日数) 、d (日) 、w (一周的日数) 、ww (周) 、h (小时) 、n (分钟) 、s (秒)

其中firstdayofweek 参数可以有以下值:

(以下分别为:常数 值 描述)

vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbSunday 1 星期日(默认)
vbMonday 2 星期一
vbTuesday 3 星期二
vbWednesday 4 星期三
vbThursday 5 星期四
vbFriday 6 星期五
vbSaturday 7 星期六
firstweekofyear 参数可以有以下值:

(以下分别为:常数 值 描述)

vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbFirstJan1 1 由 1 月 1 日所在的星期开始(默认)。
vbFirstFourDays 2 由在新年中至少有四天的第一周开始。
vbFirstFullWeek 3 由在新的一年中第一个完整的周(不跨年度)开始。
说明:DatePart 函数用于计算日期并返回指定的时间间隔。例如使用 DatePart 计算某一天是星期几或当前的时间。

其中firstdayofweek 参数会影响使用“w”和“ww”间隔符号的计算。

如果 date 是日期文字,则指定的年度会成为日期的固定部分。但是如果 date 被包含在引号 (“ ”) 中,并且省略年份,则在代码中每次计算 date 表达式时,将插入当前年份。这样就可以编写适用于不同年份的程序代码!

以上所述就是本文的全部内容了,希望能够对大家熟练掌握php有所帮助。

请您花一点时间将文章分享给您的朋友或者留下评论。我们将会由衷感谢您的支持!

PHP 相关文章推荐
十天学会php之第二天
Oct 09 PHP
PHP下一个非常全面获取图象信息的函数
Nov 20 PHP
php.ini修改php上传文件大小限制的方法详解
Jun 17 PHP
php 批量添加多行文本框textarea一行一个
Jun 03 PHP
PHP中把数据库查询结果输出为json格式简单实例
Apr 09 PHP
再推荐十款免费的php开发工具
Nov 09 PHP
PHP 7.0.2 正式版发布
Jan 08 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
Mar 15 PHP
[原创]php实现子字符串位置相互对调互换的方法
Jun 02 PHP
PHP查询大量数据内存耗尽问题的解决方法
Oct 28 PHP
PHP 代码简洁之道(小结)
Oct 16 PHP
Laravel框架基础语法与知识点整理【模板变量、输出、include引入子视图等】
Dec 03 PHP
PHP连接access数据库
Mar 27 #PHP
使用新浪微博API的OAuth认证发布微博实例
Mar 27 #PHP
新浪微博OAuth认证和储存的主要过程详解
Mar 27 #PHP
php简单实现无限分类树形列表的方法
Mar 27 #PHP
PHP调用.NET的WebService 简单实例
Mar 27 #PHP
PHP输出日历表代码实例
Mar 27 #PHP
使用php转义输出HTML到JavaScript
Mar 27 #PHP
You might like
PHP Pear 安装及使用
2009/03/19 PHP
PHP文件上传类实例详解
2016/04/08 PHP
mysql desc(DESCRIBE)命令实例讲解
2016/09/24 PHP
js客户端快捷键管理类的较完整实现和应用
2010/06/08 Javascript
js字符串转换成xml对象并使用技巧解读
2013/04/18 Javascript
js+CSS实现弹出居中背景半透明div层的方法
2015/02/26 Javascript
JS+CSS实现可以凹陷显示选中单元格的方法
2015/03/02 Javascript
javascript实现列表切换效果
2016/05/02 Javascript
jQuery获取table行数并输出单元格内容的实现方法
2016/06/30 Javascript
jQuery Validate 数组 全部验证问题
2017/01/12 Javascript
JS中input表单隐藏域及其使用方法
2017/02/13 Javascript
详解封装基础的angular4的request请求方法
2018/06/05 Javascript
nodejs实现套接字服务功能详解
2018/06/21 NodeJs
让webpack+vue-cil项目不再自动打开浏览器的方法
2018/09/27 Javascript
vue移动端实现手机左右滑动入场动画
2020/06/17 Javascript
解决layer.msg 不居中 ifram中的问题
2019/09/05 Javascript
初学vue出现空格警告的原因及其解决方案
2019/10/31 Javascript
js常用方法、检查是否有特殊字符串、倒序截取字符串操作完整示例
2020/01/26 Javascript
vue跳转页面的几种方法(推荐)
2020/03/26 Javascript
Python采用socket模拟TCP通讯的实现方法
2014/11/19 Python
利用python代码写的12306订票代码
2015/12/20 Python
Python3实现发送QQ邮件功能(附件)
2020/12/23 Python
Python中使用遍历在列表中添加字典遇到的坑
2019/02/27 Python
Python3利用print输出带颜色的彩色字体示例代码
2019/04/08 Python
Python八皇后问题解答过程详解
2019/07/29 Python
如何在Cloud Studio上执行Python代码?
2019/08/09 Python
英国户外玩具儿童游乐设备网站:TP Toys(蹦床、攀爬框架、秋千、滑梯和游戏屋)
2018/04/09 全球购物
彪马土耳其官网:PUMA土耳其
2019/07/14 全球购物
优秀员工个人的自我评价
2013/11/29 职场文书
高二化学教学反思
2014/01/30 职场文书
孟佩杰观后感
2015/06/17 职场文书
学籍证明模板
2015/06/18 职场文书
2019年手机市场的调研报告2篇
2019/10/10 职场文书
导游词之北京明十三陵
2019/10/28 职场文书
关于python爬虫应用urllib库作用分析
2021/09/04 Python
Nginx 常用配置
2022/05/15 Servers