php+mysql 處理時間

來源:互聯網
上載者:User
這篇文章主要介紹了關於php+mysql 處理時間,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

雖然mysql中有自己的時間類型,但是為了相容性考慮,php中一般用time函數取出unix時間戳記。儲存到資料庫中。
1.unix時間戳記
PHP中的time函數返回的就是unix timestamp,預設情況下PHP解析顯示位格林威治標準時間。
是從1970年1月1日(UTC/GMT的午夜)開始所經過的秒數。
2.unix時間戳記轉化為人類識別日期

$str = date(“Y-m-d H:i:s”, time())得出的是格林威治時間,非中國時間。加上8小時即可。$str = date(“Y-m-d H:i:s”, time()+8*3600)

將unix時間戳記轉化為中國時間:
3.人類識別日期轉化為unix時間戳記

$int = strtotime(“2014-11-8 08:12:24”);

4.資料庫類型
由於mysql資料庫的int範圍和unix時間戳記類型一樣,所以直接crime int,即可。create time用int表示。看有些sql檔案中顯示 crime int(11),這個括弧中的11是mysql預設的顯示長度,而非資料大小的長度。
mysql中int預設為(-2 147 483 648,2 147 483 647),10位可以滿足需求。
5.將目前時間寫入資料庫

$n = time();$query = "insert into time_test values( $n )";$ret = mysql_query($query, $con);

6.將資料庫時間顯示為中國時間

$query = "select ctime from time_test;";$ret = mysql_query($query, $con);if(!$ret){die("query error: " . mysql_error());}while ( $arr = mysql_fetch_array($ret)){//資料庫中取出的是字串,為保險起見,轉換為int類型。echo date("Y-m-d H:i:s", intval($arr["ctime"]) + 8*3600) . "<br>";}

<完>

以上就是本篇文章的全部內容了,感謝大家閱讀。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.