我目前有一个mySQL数据库,其中包含两个文本字段:Date和Time。它们分别是'dd/mm/yyyy‘和'0:00’格式,例如'11/08/2020‘和19:12。我希望创建第三个字段,称为Timestamp (类型为INT),并将两个原始字段转换为这个时间戳字段,并删除日期/时间文本字段。
我已经做了一些关于使用UNIX_TIMESTAMP()和STR_TO_DATE()的研究,但是我似乎无法让它工作,格式似乎是错误的。
如何在SQL中实现这一点,并将两个表示日期和时间的字符串字段转换为第三个字段来替换它们,这两个字段只存储unix时间戳?
这是我迄今为止最好的尝试。
SELECT UNIX_TIMESTAMP(STR_TO_DATE(CONCAT(`InfractionDate`, " ", `InfractionTime`), '%d %M %Y %h:%i%p')) FROM `playerinfractions`表名为playerinfractions,日期/时间存储在文本字段InfractionDate和InfractionTime中。
事先非常感谢!
发布于 2020-08-11 18:26:47
在函数STR_TO_DATE()中使用的格式模式是错误的。
试试这个:
SELECT
UNIX_TIMESTAMP(
STR_TO_DATE(
CONCAT(`InfractionDate`, ' ', `InfractionTime`),
'%d/%m/%Y %H:%i')
)
FROM `playerinfractions`发布于 2020-08-11 18:31:19
您需要告诉STR_TO_DATE您的日期和时间的正确格式,这是您建议的'%d/%m/%Y %H:%i'格式
SELECT UNIX_TIMESTAMP(
STR_TO_DATE(
CONCAT('10/08/2020', ' ', '12:20'), '%d/%m/%Y %H:%i' )
)
)
FROM `playerinfractions`所以使用你的列
SELECT UNIX_TIMESTAMP(
STR_TO_DATE(
CONCAT(`InfractionDate`, ' ', `InfractionTime`), '%d/%m/%Y %H:%i' )
)
)
FROM `playerinfractions`发布于 2020-08-11 18:42:59
我尝试以下面的格式将一个字符串传递给相同的函数,结果成功了。此外,您还可以共享您的格式,以进一步检查它。
select UNIX_TIMESTAMP(STR_TO_DATE(CONCAT('8/12/2020',' ', '12:01:49' ),'%m/%d/%Y %h:%i:%s'))https://stackoverflow.com/questions/63364086
复制相似问题