2017-10-15 33 views
2

我正在计算数据库中的日期和当前时间之间的差异。我在我的PHP代码中使用了一个名为TimeAgo()的函数。当减去年份它返回不同的结果

TimeAgo()代码:

function TimeAgo ($oldTime, $newTime) 
    { 
     $timeCalc = strtotime($newTime) - strtotime($oldTime); 
     if ($timeCalc >= (60*60*24*30*12*2)){ 
      $timeCalc = intval($timeCalc/60/60/24/30/12) . " years ago"; 
     }else if ($timeCalc >= (60*60*24*30*12)){ 
      $timeCalc = intval($timeCalc/60/60/24/30/12) . " year ago"; 
     }else if ($timeCalc >= (60*60*24*30*2)){ 
      $timeCalc = intval($timeCalc/60/60/24/30) . " months ago"; 
     }else if ($timeCalc >= (60*60*24*30)){ 
      $timeCalc = intval($timeCalc/60/60/24/30) . " month ago"; 
     }else if ($timeCalc >= (60*60*24*2)){ 
      $timeCalc = intval($timeCalc/60/60/24) . " days ago"; 
     }else if ($timeCalc >= (60*60*24)){ 
      $timeCalc = " Yesterday"; 
     }else if ($timeCalc >= (60*60*2)){ 
      $timeCalc = intval($timeCalc/60/60) . " hours ago"; 
     }else if ($timeCalc >= (60*60)){ 
      $timeCalc = intval($timeCalc/60/60) . " hour ago"; 
     }else if ($timeCalc >= 60*2){ 
      $timeCalc = intval($timeCalc/60) . " minutes ago"; 
     }else if ($timeCalc >= 60){ 
      $timeCalc = intval($timeCalc/60) . " minute ago"; 
     }else if ($timeCalc > 0){ 
      $timeCalc .= " seconds ago"; 
     }else if ($timeCalc == 0){ 
      $timeCalc = "Just now"; 
     } 
     return $timeCalc; 
    } 

一切正常,直到大约在数据库中的值我一塌糊涂。如果我将日期设置为1901-01-01 00:00:00,则应将结果返回为116 years ago,但它会显示为​​。

我使用此代码显示输出:

echo TimeAgo($db_user['far_date'], date("Y-m-d H:i:s")) 

有一些简单的我失踪PHP计算日期时间是什么时候?

+0

时间戳的有效范围通常是从周五,1901年12月13日20:45:54 UTC到2038年1月19日03:14:07 UTC。 (这些是与32位有符号整数的最小值和最大值对应的日期。) –

+1

如果您需要更大范围的日期,则使用64位PHP(它以64位时间戳值工作)或使用DateTime对象 –

回答

2

我认为这取决于所使用的PHP版本。我在网上找到了:

但是,在PHP 5.1.0之前,在某些系统(例如Windows)上,这个范围从01-01-1970到19-01-2038是有限的。

因此,这个默认日期发生在48年前,这与您所得到的一致。

在较新版本的范围是:Fri, 13 Dec 1901 20:45:54 GMT to Tue, 19 Jan 2038 03:14:07 GMT.

如果你真的想用这个日期,那么我劝你还是直接做在MySQL,这是我记得使用范围是从1000年。

+1

“如果你真的想使用这个日期,那么我建议你直接在MySQL上执行它,我记得使用0001年的范围”。否DATE类型用于具有日期部分的值,但不是时间部分。 MySQL以'YYYY-MM-DD'格式检索并显示DATE值。支持的范围是'1000-01-01'到'9999-12-31'。 –

+0

他想要显示的是过去的年数。他不在乎时间部分。我会编辑最低日期,但对他来说仍然足够。 @RaymondNijland – sagi