sql >> Databáze >  >> RDS >> Mysql

výpočet a zobrazení data jako „před sekundami“, „před minutami“, „před hodinami“ atd.

Můžete použít následující funkci a volat ji jako format_interval(time() - $saved_timestamp) , kde $saved_timestamp je časové razítko "události", o kterou se zajímáte. (Následující kód je licencován pod GNU General Public License v2 nebo následující .)

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 je počet různých jednotek k zobrazení. Například format_interval(32745600) vrátí "1 year 2 weeks" .

Kód, který zobrazujem, je zmenšená verze format_interval() který je dodáván s Drupalem 7, což je kód distribuovaný pod GNU General Public License v2 nebo následující licence. (Viz také COPYRIGHT.txt )
Odstranil jsem část, která je velmi specifická pro Drupal, a nechal kód, který používá jednoduché funkce PHP.



  1. Název tabulky jako parametr funkce PostgreSQL

  2. 4 způsoby, jak zobrazit seznam všech pohledů v databázi MariaDB

  3. cx_Oracle se nepřipojí při použití SID místo názvu služby v připojovacím řetězci

  4. Kód chyby:1222. Použité příkazy SELECT mají jiný počet sloupců