首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将日期和时间文本字段转换为SQL中的INT unix时间戳字段

将日期和时间文本字段转换为SQL中的INT unix时间戳字段
EN

Stack Overflow用户
提问于 2020-08-11 18:14:35
回答 3查看 68关注 0票数 1

我目前有一个mySQL数据库,其中包含两个文本字段:DateTime。它们分别是'dd/mm/yyyy‘和'0:00’格式,例如'11/08/2020‘和19:12。我希望创建第三个字段,称为Timestamp (类型为INT),并将两个原始字段转换为这个时间戳字段,并删除日期/时间文本字段。

我已经做了一些关于使用UNIX_TIMESTAMP()和STR_TO_DATE()的研究,但是我似乎无法让它工作,格式似乎是错误的。

如何在SQL中实现这一点,并将两个表示日期和时间的字符串字段转换为第三个字段来替换它们,这两个字段只存储unix时间戳?

这是我迄今为止最好的尝试。

代码语言:javascript
复制
SELECT UNIX_TIMESTAMP(STR_TO_DATE(CONCAT(`InfractionDate`, " ", `InfractionTime`), '%d %M %Y %h:%i%p')) FROM `playerinfractions`

表名为playerinfractions,日期/时间存储在文本字段InfractionDateInfractionTime中。

事先非常感谢!

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-08-11 18:26:47

在函数STR_TO_DATE()中使用的格式模式是错误的。

试试这个:

代码语言:javascript
复制
SELECT 
  UNIX_TIMESTAMP(
    STR_TO_DATE(
      CONCAT(`InfractionDate`, ' ', `InfractionTime`), 
      '%d/%m/%Y %H:%i')
  )     
FROM `playerinfractions`
票数 2
EN

Stack Overflow用户

发布于 2020-08-11 18:31:19

您需要告诉STR_TO_DATE您的日期和时间的正确格式,这是您建议的'%d/%m/%Y %H:%i'格式

代码语言:javascript
复制
SELECT UNIX_TIMESTAMP( 
            STR_TO_DATE( 
                CONCAT('10/08/2020', ' ', '12:20'), '%d/%m/%Y %H:%i' ) 
            )
        )
FROM `playerinfractions`

所以使用你的列

代码语言:javascript
复制
SELECT UNIX_TIMESTAMP( 
            STR_TO_DATE( 
                CONCAT(`InfractionDate`, ' ', `InfractionTime`), '%d/%m/%Y %H:%i' ) 
            )
        )
FROM `playerinfractions`
票数 1
EN

Stack Overflow用户

发布于 2020-08-11 18:42:59

我尝试以下面的格式将一个字符串传递给相同的函数,结果成功了。此外,您还可以共享您的格式,以进一步检查它。

代码语言:javascript
复制
select UNIX_TIMESTAMP(STR_TO_DATE(CONCAT('8/12/2020',' ', '12:01:49' ),'%m/%d/%Y %h:%i:%s'))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63364086

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档