хотите сравнить значение strtotime с currenttime и выводом: что-то x мин. назад - PullRequest
2 голосов
/ 29 июня 2010

Я работаю над новостной лентой, похожей на Facebook. Где я сравниваю время, когда что-то произошло в моей таблице mysql, с текущим временем и выводом: что-то произошло x мин назад

Сначала я подключаюсь к mysql с помощью этого кода:

        $conn = db_connect();
        $newsfeed = $conn->query("select info, username, time from newsfeed ORDER BY time DESC LIMIT 10");
        if (!$newsfeed) {
        //die(msg(0,"Could not execute query"));
        }

Я новичок в MySQL, поэтому я не уверен, что это правильно. Я хочу, чтобы последние 10 обновлений в базе данных отображались со следующими функциями с последними обновлениями над остальными:

        $newsfeed_info_array = $newsfeed->fetch_array(MYSQLI_NUM);
        $newsfeed_info = $newsfeed_info_array[0];   
        $newsfeed_username = $newsfeed_info_array[1];   
        $newsfeed_time= $newsfeed_info_array[2];
        $newsfeed_info_split = explode("-", $newsfeed_info);    //type and info

        date_default_timezone_set('Europe/Paris');
        $current_time = strtotime("now"); 

        if ($newsfeed_info_split[0] == "reg")
            {
                            //The next line is the problem
            $time_diff = date_diff($current_time, $newsfeed_time); 
            echo "<p>User $newsfeed_username just registerted ".date( "00:i:s", $newsfeed_time)." min ago</p><br>";  
            }

        if ($newsfeed_info_split[0] == "xxx")
            {
            echo "blabla x min ago"
            }

Ответы [ 2 ]

2 голосов
/ 29 июня 2010

Я использую это (адаптировано из Codeigniter Forums - Nicer Dates ):

if( ! function_exists('relative_time'))
{
    function relative_time($datetime)
    {
        if(!$datetime)
        {
            return "no data";
        }

        if(!is_numeric($datetime))
        {
            $val = explode(" ",$datetime);
            $date = explode("-",$val[0]);
            $time = explode(":",$val[1]);
            $datetime = mktime($time[0],$time[1],$time[2],$date[1],$date[2],$date[0]);
        }

        $difference = time() - $datetime;
        $periods = array("second", "minute", "hour", "day", "week", "month", "year", "decade");
        $lengths = array("60","60","24","7","4.35","12","10");

        if ($difference > 0)
        {
            $ending = 'ago';
        }
        else
        {
            $difference = -$difference;
            $ending = 'to go';
        }
        for($j = 0; $difference >= $lengths[$j]; $j++)
        {
            $difference /= $lengths[$j];
        }
        $difference = round($difference);

        if($difference != 1)
        {
            $period = strtolower($periods[$j].'s');
        } else {
            $period = strtolower($periods[$j]);
        }

        return "$difference $period $ending";
    }


}
2 голосов
/ 29 июня 2010

Поскольку вы используете unix_timespan, это только вопрос использования базовых математических данных :) Unix timespan - это количество секунд с 1 января 1970 года 00:00:00 UTC.http://en.wikipedia.org/wiki/Unix_time


$postTime = $newsfeed_into_array[2]; 
$now = time();
$seconds = $now - $postTime; // $seconds now contains seconds since post time

$minutes = ceil($span / 60); // minutes since post time

В качестве альтернативы вы можете сделать функцию, которая печатает секунды, минуты, часы и т. Д.

...