mysql中的timestamp類型時間比較:unix_timestamp函數

在mysql中,某字段的類型設置爲了timestamp,那麼咱們如今但願取出指定時間段的記錄,該如何作呢?php

在php中有time()和strtotime()來進行日期和時間戳的格式化,而在mysql中也有相似的函數,它們就是unix_timestamp()和from_unixtime()函數html

舉例說明,參考以下sql語句:mysql

1 Select *
2 FROM (`x60_usr_subscribe`)
3 Where `status` =  1
4 AND unix_timestamp(stime) > 1351085010
5 AND unix_timestamp(stime) < 1354685130
1 Select
2 (UNIX_TIMESTAMP(endtime)-UNIX_TIMESTAMP(startime))/31536000, `year`, `id`, `name`
3 FROM `testime`
4 LIMIT 0,30

關於函數UNIX_TIMESTAMP()與UNIX_TIMESTAMP(date)web

若無參數調用,則返回一個 Unix timestamp ('1970-01-01 00:00:00' GMT 以後的秒數) 做爲無符號整數。若用date 來調用 UNIX_TIMESTAMP(),它會將參數值以'1970-01-01 00:00:00' GMT後的秒數的形式返回。date 能夠是一個 DATE 字符串、一個 DATETIME字符串、一個 TIMESTAMP或一個當地時間的YYMMDD 或YYYMMDD格式的數字。sql

1 mysql> Select UNIX_TIMESTAMP();
2 ->  1354684110
3 mysql> Select UNIX_TIMESTAMP('1997-10-04 22:23:00');
4 -> 875996580

當 UNIX_TIMESTAMP 被用在 TIMESTAMP列時, 函數直接返回內部時戳值, 而不進行任何隱含的 「string-to-Unix-timestamp」轉化。假如你向UNIX_TIMESTAMP()傳遞一個溢出日期,它會返回 0,但請注意只有基本範圍檢查會被履行 (年份從1970 到 2037, 月份從01 到12,日期從 01 到31)。函數

       這裏咱們能夠使用FROM_UNIXTIME(unix_timestamp), FROM_UNIXTIME(unix_timestamp,format)
來格式化一個UNIX_TIMESTAMP()時間戳,它將返回'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS 格式值的unix_timestamp參數表示,具體格式取決於該函數是否用在字符串中或是數字語境中。
若format 已經給出,則結果的格式是根據format 字符串而定。 format 能夠包含同DATE_FORMAT() 函數輸入項列表中相同的說明符。spa

此外,mysql中還有其餘衆多關於時間日期的函數,具體可參看這裏:unix

http://lzw.me/Category/Learning/mysql-replace-string.html
http://baike.baidu.com/view/2140086.htm#4code

相關文章
相關標籤/搜索