天天看點

MySQL中from_unixtime和unix_timestamp處理資料庫時間戳轉換問題

作者:IT萌寵

MySQL資料表設計中,時間字段一般都設計為時間戳格式的,開發人員去檢視的時候就顯得有點不友善。可以使用FROM_UNIXTIME轉換成日期格式進行檢視

如果是日期格式的,要轉換成時間戳檢視呢,隻需要把FROM_UNIXTIME換成UNIX_TIMESTAMP即可

案例一

SELECT *,FROM_UNIXTIME(create_time) AS DATETIME FROM ebk_cls_io_log;           
MySQL中from_unixtime和unix_timestamp處理資料庫時間戳轉換問題

案例二

select  from_unixtime(at2.payTime, '%Y-%m-%d'), sum(at2.amount) from alipay_trade at2 group by from_unixtime(at2.payTime, '%Y-%m-%d');           
MySQL中from_unixtime和unix_timestamp處理資料庫時間戳轉換問題

彙總

1、時間轉時間戳

擷取目前時間戳(秒)

select unix_timestamp();

結果:1599665897

擷取指定格式日期時間戳

select unix_timestamp('2020-9-9');

結果:1599580800

擷取指定格式日期和時間戳的時間戳

select unix_timestamp('2020-9-9 23:49:20');

結果:1599666560

2、時間戳轉時間

文法:FROM_UNIXTIME(unix_timestamp,format)

時間戳(unix_timestamp)為10位

select from_unixtime(1599666560,'%Y-%m-%d %H:%i:%S');

結果:2020-09-09 23:49:20

格式 描述 示例 運作結果
%a 英文縮寫星期名 SELECT FROM_UNIXTIME(1599666560,’%a’); Tue
%b 英文縮寫月名 SELECT FROM_UNIXTIME( Now( ), ‘%b’ ) Sep
%c 月,數值 SELECT FROM_UNIXTIME( Now( ), ‘%c’ ) 9
%D 帶有英文字首的月中的第幾天 SELECT FROM_UNIXTIME( Now( ), ‘%D’ ) 9th
%d 月的天,數值(00-31) SELECT FROM_UNIXTIME( Now( ), '%d ’ ) 09
%e 月的天,數值(0-31) SELECT FROM_UNIXTIME( Now( ), '%e ’ ) 9
%f 微秒 SELECT FROM_UNIXTIME(1599666560 , '%f ’ ) 000000
%H 小時 (00-23) SELECT FROM_UNIXTIME(1599666560 , '%H ’ ) 23
%h 小時 (01-12) SELECT FROM_UNIXTIME(1599666560 , '%h ’ ) 11
%I 小時 (01-12) SELECT FROM_UNIXTIME(1599666560, ‘%I’ ) 11
%i 分鐘,數值(00-59) SELECT FROM_UNIXTIME(1599666560, ‘%i’ ) 49
%j 年的天 (001-366) SELECT FROM_UNIXTIME(1599666560, ‘%j’ ) 253
%k 小時 (0-23) SELECT FROM_UNIXTIME(1599666560, ‘%k’ ) 23
%l 小時 (1-12) SELECT FROM_UNIXTIME(1599666560, ‘%l’ ) 11
%M 月份,英文 SELECT FROM_UNIXTIME(1599666560, ‘%M’ ) September
%m 月份,數值(00-12) SELECT FROM_UNIXTIME(1599666560, ‘%m’ ) 09
%p 上下午 SELECT FROM_UNIXTIME(1599666560, ‘%p’ ) PM
%r 時間,12-小時(hh:mm:ss AM 或 PM) SELECT FROM_UNIXTIME(1599666560, ‘%r’ ) 11:49:20 PM
%S 秒(00-59) SELECT FROM_UNIXTIME(1599666560, ‘%S’ ) 20
%s 秒(00-59) SELECT FROM_UNIXTIME(1599666560, ‘%s’ ) 20
%T 時間, 24-小時 (hh:mm:ss) SELECT FROM_UNIXTIME(1599666560, ‘%T’ ) 23:49:20
%U 周 (00-53) 星期日是一周的第一天 SELECT FROM_UNIXTIME(1599666560, ‘%U’ ) 36
%u 周 (00-53) 星期一是一周的第一天 SELECT FROM_UNIXTIME(1599666560, ‘%u’ ) 37
%V 周 (01-53) 星期日是一周的第一天,與 %X 使用 SELECT FROM_UNIXTIME(1599666560, ‘%V’ ) 36
%v 周 (01-53) 星期一是一周的第一天,與 %x 使用 SELECT FROM_UNIXTIME(1599666560, ‘%v’ ) 37
%W 周幾,英文全稱 SELECT FROM_UNIXTIME(1599666560, ‘%W’ ) Wednesday
%w 周的天 (0=星期日, 6=星期六) SELECT FROM_UNIXTIME(1599666560, ‘%w’ ) 3
%X 年,4 位,其中的星期日是周的第一天,與 %V 使用 SELECT FROM_UNIXTIME(1599666560, ‘%X’ ) 2020
%x 年,4 位,其中的星期一是周的第一天,與 %v 使用 SELECT FROM_UNIXTIME(1599666560, ‘%x’ ) 2020
%Y 年,4 位 SELECT FROM_UNIXTIME(1599666560, ‘%Y’ ) 2020
%y 年,2 位 SELECT FROM_UNIXTIME(1599666560, ‘%y’ ) 20

繼續閱讀