sql >> データベース >  >> RDS >> Mysql

日付を計算して「数秒前」、「数分前」、「数時間前」などとして表示する

    次の関数を使用して、format_interval(time() - $saved_timestamp)として呼び出すことができます。 、ここで$saved_timestamp は、関心のある「イベント」のタイムスタンプです。(次のコードは、 GNU General PublicLicensev2以降でライセンスされています。 。)

    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は、表示するさまざまなユニットの数です。例:format_interval(32745600) "1 year 2 weeks"を返します 。

    私が示しているコードは、 format_interval() これは、GNUGeneralの下で配布されるコードであるDrupal7に付属しています。 PublicLicensev2以降 ライセンス。 (COPYRIGHT.txt も参照してください。 )
    Drupalに非常に固有の部分を削除し、プレーンなPHP関数を使用するコードを残しました。



    1. WSJDBCConnectionは、タイプOraclejdbcConnectionのオブジェクトをラップしません

    2. 表の印刷がページサイズに適合しない

    3. .net用の代替Oracleドライバ

    4. 何百万ものエントリでランキング