In order to improve query efficiency, we usually use int(11) type timestamp to store time. But this has a disadvantage. The displayed timestamp makes it difficult to know the real date and time.
mysql provides a timestamp formatting function from_unixtime to convert the format
from_unxitime syntax description:
from_unixtime(unix_timestamp, format)
Returns a string of Unix time stamp , formatted according to format. If format is not set, the format %Y-%m-%d %H:%i:%s
is used by default. For example:
mysql> select from_unixtime(1459338786); +---------------------------+ | from_unixtime(1459338786) | +---------------------------+ | 2016-03-30 19:53:06 | +---------------------------+ 1 row in set (0.00 sec) mysql> select from_unixtime(1459338786, '%Y-%m-%d %H:%i:%s'); +------------------------------------------------+ | from_unixtime(1459338786, '%Y-%m-%d %H:%i:%s') | +------------------------------------------------+ | 2016-03-30 19:53:06 | +------------------------------------------------+ 1 row in set (0.00 sec)
format Format description:
%M Month name (January~December)
mysql> select from_unixtime(addtime,'%Y-%m-%d %H') as date,count(*) from `table` group by from_unixtime(addtime,'%Y-%m-%d %H');+---------------+----------+| date | count(*) |+---------------+----------+| 2016-03-30 19 | 409 || 2016-03-30 20 | 161 |+---------------+----------+2 rows in set (0.00 sec)
The above is the detailed content of How to use the mysql timestamp format function from_unixtime. For more information, please follow other related articles on the PHP Chinese website!