sql >> Database teknologi >  >> RDS >> Mysql

Beregner forskel mellem to datoer i PHP

du kan bruge funktionen date_diff()

http://php.net/manual/en/function.date-diff .php

Noget i stil med...

<?php 
$now = time();
$then = $posttime;
$diff = date_diff($now,$then);
echo $diff->format('%R%d days'); #change format for different timescales
?>

rediger --

Jeg løser faktisk dette problem på en af ​​mine twitter-apps ved hjælp af denne funktion...

function time_since ( $start )
{
    $end = time();
    $diff = $end - $start;
    $days = floor ( $diff/86400 ); //calculate the days
    $diff = $diff - ($days*86400); // subtract the days
    $hours = floor ( $diff/3600 ); // calculate the hours
    $diff = $diff - ($hours*3600); // subtract the hours
    $mins = floor ( $diff/60 ); // calculate the minutes
    $diff = $diff - ($mins*60); // subtract the mins
    $secs = $diff; // what's left is the seconds;
    if ($secs!=0) 
    {
        $secs .= " seconds";
        if ($secs=="1 seconds") $secs = "1 second"; 
    }
    else $secs = '';
    if ($mins!=0) 
    {
        $mins .= " mins ";
        if ($mins=="1 mins ") $mins = "1 min "; 
        $secs = '';
    }
    else $mins = '';
    if ($hours!=0) 
    {
        $hours .= " hours ";
        if ($hours=="1 hours ") $hours = "1 hour ";             
        $secs = '';
    }
    else $hours = '';
    if ($days!=0) 
    {
        $days .= " days "; 
        if ($days=="1 days ") $days = "1 day ";                 
        $mins = '';
        $secs = '';
        if ($days == "-1 days ") {
            $days = $hours = $mins = '';
            $secs = "less than 10 seconds";
        }
    }
    else $days = '';
    return "$days $hours $mins $secs ago";
}

Du sender det i et unix-tidsstempel for at kontrollere (posttidspunktet), og det returnerer de forskellige strenge.



  1. Sådan formateres dato og klokkeslæt i MySQL

  2. Hjælp venligst med at forbedre SQL Server-statistikker!

  3. Hvordan SUBDATE() virker i MariaDB

  4. Multiplikation af data fra MySQL række