程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> mysql時間戳轉換函數 unix_timestamp和from_unixtime使用方法

mysql時間戳轉換函數 unix_timestamp和from_unixtime使用方法

編輯:關於MYSQL數據庫

     1.unix_timestamp

    將時間轉化為時間戳。將 date 類型數據轉換成 timestamp 時間戳形式

    默認取當前時間的時間戳

    mysql> select unix_timestamp();
    +——————+
    | unix_timestamp() |
    +——————+
    |       1436775578 |
    +——————+
    1 row in set (0.01 sec)

     

    mysql> select unix_timestamp('2015-07-13 16:20:20');
    +—————————————+
    | unix_timestamp('2015-07-13 16:20:20') |
    +—————————————+
    |                            1436775620 |
    +—————————————+
    1 row in set (0.00 sec)

     

    2.from_unixtime

    將時間戳 timestamp 形式整數 轉化為 date 類型

    mysql>  select from_unixtime(1436775620);
    +—————————+
    | from_unixtime(1436775620) |
    +—————————+
    | 2015-07-13 16:20:20       |
    +—————————+
    1 row in set (0.00 sec)

    當然也可以指定輸出的時間格式:

    mysql>  select from_unixtime(1436775620,'%Y%m%d');
    +————————————+
    | from_unixtime(1436775620,'%Y-%m-%d') |
    +————————————+
    | 2015-07-13                           |
    +————————————+

     

    3.關於mysql 時間戳的限制

    目前timestamp 所能表示的范圍在 1970  -  2038之間 。

    超過這個范圍 得到的時間將會溢出 得到的時間是null.

    mysql>  select from_unixtime(0);
    +———————+
    | from_unixtime(0)    |
    +———————+
    | 1970-01-01 08:00:00 |
    +———————+

    mysql> select from_unixtime(2247483647);
    +—————————+
    | from_unixtime(2247483647) |
    +—————————+
    | 2038-01-19 11:14:07       |
    +—————————+
    1 row in set (0.00 sec)

    4、除了mysql php也可以達到同樣的效果,例子如下

    (完整的 年月日時分秒)
     
    php中UNIX時間戳轉換為日期用函數 : date()
     
    date('Y-m-d H:i:s', 1156219870);
     
    php中日期轉換為UNIX時間戳用函數 :strtotime()
     
    strtotime('2010-03-24 08:15:42');

    PHP 提供了函數可以方便的將各種形式的日期轉換為時間戳,該類函數主要是:

    strtotime():將任何英文文本的日期時間描述解析為時間戳。
    mktime():從日期取得時間戳。
    strtotime()

    strtotime() 函數用於將英文文本字符串表示的日期轉換為時間戳,為 date() 的反函數,成功返回時間戳,否則返回 FALSE 。語法:

    int strtotime ( string time [, int now] )
    參數 time 為被解析的字符串,是根據 GNU 日期輸入格式表示的日期。

    例子:

    <?php
    echo strtotime("2009-10-21 16:00:10"); //輸出 1256112010
    echo strtotime("10 September 2008"); //輸出 1220976000
    echo strtotime("+1 day"), "<br />"; //輸出明天此時的時間戳
    ?>
    mktime()

    mktime() 函數用於從日期取得時間戳,成功返回時間戳,否則返回 FALSE 。語法:

    int mktime(時, 分, 秒, 月, 日, 年)
    例子:

    <?php
    echo mktime(21, 50, 55, 07, 14, 2010);  //輸出“1279115455”
    ?>
    參數可以從右向左省略,任何省略的參數會被設置成本地日期和時間的當前值。

    mktime() 在做日期計算和驗證方面很有用,它會自動計算超出范圍的輸入的正確值。例如下面例子輸出的都是 2008-01-01:

    <?php
    echo date("Y-m-d", mktime(0, 0, 0, 12, 32, 2007));
    echo date("Y-m-d", mktime(0, 0, 0, 13, 1, 2007));
    ?>
    下個月的最後一天。任何給定月份的最後一天都可以被表示為下個月的第 "0" 天,而不是 -1 天,如下面的例子:

    <?php
    $lastday = mktime(0, 0, 0, 3, 0, 2008);
    echo strftime("2008年最後一天是:%d", $lastday);
    // 2008年最後一天是:29
    ?>
    自定義函數

    下面的函數與strtotime功能差不多。

    <?php
    $date_str = "2011-09-11 17:00:00";
    echo $time_str = str_format_time($date_str);

    function str_format_time($timestamp = '')
    {  
     if (preg_match("/[0-9]{4}-[0-9]{1,2}-[0-9]{1,2} (0[0-9]|1[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])/i", $timestamp))
     {
      list($date,$time)=explode(" ",$timestamp);
      list($year,$month,$day)=explode("-",$date);
         list($hour,$minute,$seconds )=explode(":",$time);
       $timestamp=gmmktime($hour,$minute,$seconds,$month,$day,$year);
     }
     else
     {
      $timestamp=time();
     }
     return $timestamp;
    }

    echo '<br />';
    echo date("Y-m-d H:i:s", $time_str);

    ?>

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved