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

beregne og vise en dato som 'sekunder siden', 'mins siden', 'timer siden' osv.

Du kan bruge følgende funktion og kalde den som format_interval(time() - $saved_timestamp) , hvor $saved_timestamp er tidsstemplet for den "begivenhed", du er interesseret i. (Følgende kode er licenseret under GNU General Public License v2 eller efterfølgende .)

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';
}

$granularity er antallet af forskellige enheder, der skal vises. For eksempel format_interval(32745600) ville returnere "1 year 2 weeks" .

Koden, jeg viser, er en reduceret version af format_interval() der følger med Drupal 7, som er kode distribueret under GNU General Public License v2 eller efterfølgende licens. (Se også COPYRIGHT.txt )
Jeg tog den del af, der er meget specifik for Drupal, og efterlod koden, der bruger almindelige PHP-funktioner.



  1. Lagre en fil i en database i modsætning til filsystemet?

  2. MySQL Vælg Top N rækker

  3. SQL Server Temporary Object Caching

  4. Sådan defineres en auto-inkrement primær nøgle i Oracle