在mysql中,某字段的類型設(shè)置為了timestamp,那么我們現(xiàn)在希望取出指定時間段的記錄,該如何做呢?
在php中有time()和strtotime()來進(jìn)行日期和時間戳的格式化,而在mysql中也有類似的函數(shù),它們就是unix_timestamp()和from_unixtime()函數(shù)
舉例說明,參考如下sql語句:
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
|
關(guān)于函數(shù)UNIX_TIMESTAMP()與UNIX_TIMESTAMP(date)
若無參數(shù)調(diào)用,則返回一個 Unix timestamp ('1970-01-01 00:00:00' GMT 之后的秒數(shù)) 作為無符號整數(shù)。若用date 來調(diào)用 UNIX_TIMESTAMP(),它會將參數(shù)值以'1970-01-01 00:00:00' GMT后的秒數(shù)的形式返回。date 可以是一個 DATE 字符串、一個 DATETIME字符串、一個 TIMESTAMP或一個當(dāng)?shù)貢r間的YYMMDD 或YYYMMDD格式的數(shù)字。
1
|
mysql>
?
Select
?
UNIX_TIMESTAMP();
|
2
|
->? 1354684110
|
3
|
mysql>
?
Select
?
UNIX_TIMESTAMP(
'1997-10-04 22:23:00'
);
|
4
|
-> 875996580
|
當(dāng) UNIX_TIMESTAMP 被用在 TIMESTAMP列時, 函數(shù)直接返回內(nèi)部時戳值, 而不進(jìn)行任何隱含的 “string-to-Unix-timestamp”轉(zhuǎn)化。假如你向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參數(shù)表示,具體格式取決于該函數(shù)是否用在字符串中或是數(shù)字語境中。
若format 已經(jīng)給出,則結(jié)果的格式是根據(jù)format 字符串而定。 format 可以包含同DATE_FORMAT() 函數(shù)輸入項(xiàng)列表中相同的說明符。
此外,mysql中還有其他眾多關(guān)于時間日期的函數(shù),具體可參看這里:
http://lzw.me/Category/Learning/mysql-replace-string.html
http://baike.baidu.com/view/2140086.htm#4
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
