我想将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

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


当前回答

只需使用mysql的DATE函数:

mysql> select DATE(mytimestamp) from foo;

其他回答

DATE_FORMAT(FROM_UNIXTIME(`user.registration`), '%e %b %Y') AS 'date_formatted'

只要定个日期就行了

cast(user.registration as date)

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

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

SQLFiddle演示

只需使用mysql的DATE函数:

mysql> select DATE(mytimestamp) from foo;

FROM_UNIXTIME(unix_timestamp, [format])是您所需要的全部

FROM_UNIXTIME(user.registration, '%Y-%m-%d') AS 'date_formatted'

FROM_UNIXTIME获取一个数字值并将其转换为一个DATE对象, 或者如果给定一个格式字符串,它会以字符串的形式返回。

旧的解决方案是获取初始日期对象并用第二个函数DATE_FORMAT…但这已经没有必要了

试一试:

SELECT strftime("%Y-%d-%m", col_name, 'unixepoch') AS col_name

它将以毫秒为单位将时间戳格式化为yyyy-mm-dd字符串。