在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图片上传类带图片显示
Nov 25 PHP
提示Trying to clone an uncloneable object of class Imagic的解决
Oct 27 PHP
探讨PHP JSON中文乱码的解决方法详解
Jun 06 PHP
PHP学习笔记(三):数据类型转换与常量介绍
Apr 17 PHP
PHP实现获取文件后缀名的几种常用方法
Aug 08 PHP
学习php设计模式 php实现状态模式
Dec 07 PHP
Yii视图CGridView实现操作按钮定义地址示例
Jul 14 PHP
PHP的openssl加密扩展使用小结(推荐)
Jul 18 PHP
php+mysql查询实现无限下级分类树输出示例
Oct 03 PHP
PDO操作MySQL的基础教程(推荐)
Aug 18 PHP
PHP封装的page分页类定义与用法完整示例
Dec 24 PHP
在 PHP 和 Laravel 中使用 Traits的方法
Nov 13 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 strlen mb_strlen计算中英文混排字符串长度
2009/07/10 PHP
xss防御之php利用httponly防xss攻击
2014/03/21 PHP
PHP实现HTML生成PDF文件的方法
2014/11/07 PHP
老生常谈PHP中的数据结构:DS扩展
2017/07/17 PHP
php 使用 __call实现重载功能示例
2019/11/18 PHP
JS 用6N±1法求素数 实例教程
2009/10/20 Javascript
基于Jquery的文字滚动跑马灯插件(一个页面多个滚动区)
2010/07/26 Javascript
zTree插件之多选下拉菜单实例代码
2013/11/06 Javascript
js与jquery分别实现tab标签页功能的方法
2016/11/18 Javascript
js时间控件只显示年月
2017/01/08 Javascript
详解nodejs中exports和module.exports的区别
2017/02/17 NodeJs
JS实现的JSON数组去重算法示例
2018/04/11 Javascript
基于jQuery ztree实现表格风格的树状结构
2018/08/31 jQuery
cnpm加速Angular项目创建的方法
2018/09/07 Javascript
详解微信小程序工程化探索之webpack实战
2020/04/20 Javascript
python轻松实现代码编码格式转换
2015/03/26 Python
在Python中操作列表之List.pop()方法的使用
2015/05/21 Python
Python实现JSON反序列化类对象的示例
2018/01/31 Python
python 将列表中的字符串连接成一个长路径的方法
2018/10/23 Python
python提取包含关键字的整行数据方法
2018/12/11 Python
pandas DataFrame的修改方法(值、列、索引)
2019/08/02 Python
Python IDE Pycharm中的快捷键列表用法
2019/08/08 Python
python爬虫之爬取百度音乐的实现方法
2019/08/24 Python
Python 导入文件过程图解
2019/10/15 Python
Qoo10台湾站:亚洲领先的在线市场
2018/05/15 全球购物
Watchshop德国:欧洲在线手表No.1
2019/06/20 全球购物
DC Shoes荷兰官方网站:美国极限运动品牌
2019/10/22 全球购物
卖房协议书
2014/04/11 职场文书
2014各大专业毕业生自我评价
2014/09/17 职场文书
2014年底工作总结
2014/12/15 职场文书
2015年大学生党员承诺书
2015/04/27 职场文书
2015年评职称个人工作总结
2015/10/15 职场文书
品德与社会教学反思
2016/02/24 职场文书
职工趣味运动会开幕词
2016/03/04 职场文书
十大经典日本动漫排行榜 海贼王第三,犬夜叉仅第八
2022/03/18 日漫
HTML5中的DOCUMENT.VISIBILITYSTATE属性详解
2023/05/07 HTML / CSS