sql >> Database >  >> RDS >> Mysql

een datum berekenen en weergeven als 'seconden geleden', 'minuten geleden', 'uren geleden' enz

U kunt de volgende functie gebruiken en deze aanroepen als format_interval(time() - $saved_timestamp) , waar $saved_timestamp is de tijdstempel van het "evenement" waarin u geïnteresseerd bent. (De volgende code is gelicentieerd onder GNU General Public License v2 of opeenvolgend .)

function format_interval($interval, $granularity = 2) {
  $units = array('1 year|@count years' => 31536000, '1 week|@count weeks' => 604800, '1 day|@count days' => 86400, '1 hour|@count hours' => 3600, '1 min|@count min' => 60, '1 sec|@count sec' => 1);
  $output = '';
  foreach ($units as $key => $value) {
    $key = explode('|', $key);
    if ($interval >= $value) {
      $floor = floor($interval / $value);
      $output .= ($output ? ' ' : '') . ($floor == 1 ? $key[0] : str_replace('@count', $floor, $key[1]));
      $interval %= $value;
      $granularity--;
    }

    if ($granularity == 0) {
      break;
    }
  }

  return $output ? $output : '0 sec';
}

$granulariteit is het aantal verschillende eenheden dat moet worden weergegeven. Bijvoorbeeld format_interval(32745600) zou "1 year 2 weeks" . teruggeven .

De code die ik laat zien is een gereduceerde versie van format_interval() dat wordt geleverd met Drupal 7, wat code is die wordt gedistribueerd onder GNU General Openbare licentie v2 of opeenvolgend vergunning. (Zie ook COPYRIGHT.txt )
Ik heb het gedeelte dat heel specifiek is voor Drupal verwijderd en de code gelaten die gewone PHP-functies gebruikt.



  1. Mysql DateTime groep met 15 minuten

  2. #1136 - Kolomtelling komt niet overeen met waardetelling op rij 1

  3. Door komma's gescheiden kolomgegevens in extra kolommen splitsen

  4. Python from scratch:maak een dynamische website