设为首页 收藏本站
查看: 435|回复: 0

[经验分享] PHP开发笔记系列(三)-日期与时间

[复制链接]

尚未签到

发表于 2017-4-5 11:23:18 | 显示全部楼层 |阅读模式
      前两篇完成了
《PHP开发笔记系列(一)-PDO使用》
和《PHP开发笔记系列(二)-字符串使用》
,今天开始研究一下PHP中的日期时间处理和MySQL中的日期时间处理,《PHP开发笔记系列(三)-日期与时间》




  日期时间是平常用得比较多的函数,在JAVA中我们通过new Date()可以获取服务器的当前时间,通过SimpleDateFormat类,并指定formatString,可以将date对象的值格式化成指定的形式。同理,在PHP中,同样有类似的类和函数,那就是time函数和date函数。time()类似于new Date(),能够获取服务器当前时间,date函数类似于SimpleDateFormat类。


1. 使用time函数获取服务器当前时间,使用date函数进行格式化



file:time.php
url:http://localhost:88/datetime/timephp
<?php
// 获取服务器当前时间
$time = time();
echo $time."<br/>";
// 获取当前默认是时区
echo date_default_timezone_get()."<br/>";
echo date("Y-m-d h:i:s", $time)."<br/>";
echo "<hr/>";
// 设置当前默认是时区
date_default_timezone_set("America/New_York");
echo date("Y-m-d h:i:s", $time)."<br/>";
?>
   
2. 通过字符串构造日期时间




file:strtotime.php
url:http://localhost:88/datetime/strtotime.php
<?php  
// 字符串转time类型
$time1 = strtotime("2012-05-27 10:52:05");
// 使用date函数获取星期几并输出
echo 'today:'.date("l", $time1)."<br/>";
// 使用date函数获取当月总天数并输出
echo 'total day of this month:'.date("t", $time1)."<br/>";
?>

   3. 基于当前时间的日期时间计算



file:date-compute.php
url:http://localhost:88/datetime/date-compute.php
<?php
// 计算time
$nextDay = strtotime("+1 day", time());
$lastDay = strtotime("-1 day", time());
$nextMonth = strtotime("+1 month", time());
$lastMonth = strtotime("-1 month", time());
$nextYear = strtotime("+1 year", time());
$lastYear = strtotime("-1 year", time());
echo 'new day:'.date("Y-m-d h:i:s", $nextDay)."<br/>";
echo 'last day:'.date("Y-m-d h:i:s", $lastDay)."<br/>";
echo 'next month:'.date("Y-m-d h:i:s", $nextMonth)."<br/>";
echo 'last month:'.date("Y-m-d h:i:s", $lastMonth)."<br/>";
echo 'next year:'.date("Y-m-d h:i:s", $nextYear)."<br/>";
echo 'last year:'.date("Y-m-d h:i:s", $lastYear)."<br/>";
// 通过date函数获取年份
echo 'current year:'.date("Y");
?>

  
4. 在SQL中处理日期时间




SELECT NOW()
SELECT CURRENT_TIMESTAMP();
SELECT DATE_FORMAT(NOW(), "%Y-%m-%d");
SELECT DATE_FORMAT(NOW(), "%h:%i:%s");
SELECT DATE_FORMAT(NOW(), "%W %w %p");
  5. 在SQL中进行日期计算


    使用DATE_ADD函数进行未来日期的计算


SELECT DATE_ADD(NOW(), INTERVAL 1 YEAR);
SELECT DATE_ADD(NOW(), INTERVAL 1 MONTH);
SELECT DATE_ADD(NOW(), INTERVAL 1 DAY);
SELECT DATE_ADD(NOW(), INTERVAL 1 HOUR);
SELECT DATE_ADD(NOW(), INTERVAL 1 MINUTE);
SELECT DATE_ADD(NOW(), INTERVAL 1 SECOND);
      使用DATE_SUB函数进行过去日期的计算


SELECT DATE_SUB(NOW(), INTERVAL 1 YEAR);
SELECT DATE_SUB(NOW(), INTERVAL 1 MONTH);
SELECT DATE_SUB(NOW(), INTERVAL 1 DAY);
SELECT DATE_SUB(NOW(), INTERVAL 1 HOUR);
SELECT DATE_SUB(NOW(), INTERVAL 1 MINUTE);
SELECT DATE_SUB(NOW(), INTERVAL 1 SECOND);
  
    上述函数的执行结合也可用于SQL语句当中,如查询前三天的日志信息,SQL如下:

SELECT * FROM log WHERE create_time BETWEEN SELECT DATE_SUB(NOW(), INTERVAL 3 DAY) AND SELECT DATE_ADD(NOW(), INTERVAL 1 DAY);


      本文地址:http://ryan-d.iteye.com/blog/1543363

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-360540-1-1.html 上篇帖子: Make code sweet.PHP特殊用法的一些总结(1) 下篇帖子: PHP中计算字符串相似度的函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表