我想将MySQL中的时间戳转换为日期。

我想格式化用户。将注册字段作为yyyy-mm-dd输入到文本文件中。

这是我的SQL:

$sql = requestSQL("SELECT user.email, 
                   info.name, 
                   FROM_UNIXTIME(user.registration),
                   info.news
                   FROM user, info 
                   WHERE user.id = info.id ", "export members");

我还尝试了日期转换:

DATE_FORMAT(user.registration, '%d/%m/%Y')
DATE(user.registration)

我在写入文本文件之前回显结果,我得到:

email1; name1 DATE_FORMAT(用户)。registration,‘d - m % % Y); news1 email2; name2 news2

如何将该字段转换为日期?


当前回答

如果你想改变列的数据类型,你可以简单地先从TIMESTAMP转换为INT:

ALTER TABLE table_name MODIFY column_name INT;

然后INT to DATE:

ALTER TABLE table_name MODIFY column_name DATE;

但是,如果你不想改变一个列,而只想要SELECT,那么你可以使用date()函数:

SELECT date(your_timestamp_column) FROM your_table;

其他回答

我想转换一个记录1580707260

通常,我使用在线时间戳转换器

想要在查询结果中显示它

请试试这个

DATE_FORMAT(FROM_UNIXTIME(field name from table), '%e %b %Y') 

AS '显示结果的名称'

我用'date'函数做到了这一点,如下所示:

(SELECT count(*) as the-counts,(date(timestamp)) as the-timestamps FROM `user_data` WHERE 1 group BY the-timestamps)
DATE_FORMAT(FROM_UNIXTIME(`user.registration`), '%e %b %Y') AS 'date_formatted'

如果你想改变列的数据类型,你可以简单地先从TIMESTAMP转换为INT:

ALTER TABLE table_name MODIFY column_name INT;

然后INT to DATE:

ALTER TABLE table_name MODIFY column_name DATE;

但是,如果你不想改变一个列,而只想要SELECT,那么你可以使用date()函数:

SELECT date(your_timestamp_column) FROM your_table;

只要定个日期就行了

cast(user.registration as date)

要获得特定的格式,请使用date_format

date_format(registration, '%Y-%m-%d')

SQLFiddle演示