php 日期时间运算方法总结
本文导语: 核心函数: mktime 函数 mktime() 函数返回一个日期的 Unix 时间戳。 参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。 参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。 语法 mktime(hour,minute,second,month,day,y...
核心函数:
mktime 函数
mktime() 函数返回一个日期的 Unix 时间戳。
参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。
参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。
语法
mktime(hour,minute,second,month,day,year,is_dst)
参数 描述
hour 可选。规定小时。
minute 可选。规定分钟。
second 可选。规定秒。
month 可选。规定用数字表示的月。
day 可选。规定天。
year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
is_dst 可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。
自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。
例子
mktime() 函数对于日期运算和验证非常有用。它可以自动校正越界的输入:
输出:
Jan-05-2002
Feb-01-2002
Jan-01-2001
Jan-01-1999
strtotime 函数
strtotime() 函数将任何英文文本的日期时间描述解析为 Unix 时间戳。
语法
strtotime(time,now)
参数 描述
time 规定要解析的时间字符串。
now 用来计算返回值的时间戳。如果省略该参数,则使用当前时间。
一周之后: strtotime("+1 week") ;
一周之前: strtotime("-1 week") ;
一月之后: strtotime("+1 months") ;
一天之后: strtotime("+1 days") ;
30秒之后 strtotime( " +30 seconds " );
20分钟之后 strtotime( " +20 minutes " );
12个小时之后 strtotime( " +12 hours " );
date 函数
date() 函数格式化一个本地时间/日期。
语法
date(format,timestamp)
date_default_timezone_set 函数
date_default_timezone_set() 函数设置用在脚本中所有日期/时间函数的默认时区。
语法
date_default_timezone_set(timezone)
参数 描述
timezone 必需。时区标识符,比如 "UTC" 或 "Europe/Paris"。
合法时区的列表:http://www.php.net/manual/en/timezones.php
实例
第一种情况是没有数据库,只是得到的日期值进行比较的话,那就得完全用php的时间日期函数计算了,如下:
比如要计算2009-9-5到2009-9-18还有多少天:
第二种 孩子的成长
第三种 明天,下个月和明年的日期,就可以用以下的代码:
$nextmonth = date('Y-m',mktime (0,0,0,date("m")+1,date("d")+1,date("Y")));
$nextyear = date('Y',mktime (0,0,0,date("m"),date("d"),date("Y")+1));
echo $tomorrow.'
';
echo $nextmonth.'
';
echo $nextyear.'
';
第四种 工作时间(刨除假日)
第五种 mysql 处理日期 (防灌水)
$sql = "SELECT TIME_TO_SEC(NOW())-TIME_TO_SEC(time_at) from test ";
// 或者 select time_to_sec("1980-8-20 12:25:33") - time_to_sec("1997-1-23 6:04:56")
或用
SELECT DATEDIFF('2008-12-30','2008-12-29') AS DiffDate
/*
结果:
DiffDate
1
*/
或者
/*
假设我们有如下的表:
OrderId ProductName OrderDate
1 'Computer' 2008-12-29 16:25:46.635
*/
SELECT OrderId,DATE_ADD(OrderDate,INTERVAL 2 DAY) AS OrderPayDate FROM Orders
/*
结果:
OrderId OrderPayDate
1 2008-12-31 16:25:46.635
*/
给出秒算小时 php