微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

与最新时间戳子查询的相对时间

如何解决与最新时间戳子查询的相对时间

我在雅典娜的桌子比今天晚了一周,但它一直在追赶 所以我想创建一个查询,在最新时间戳前一周为我提供所有会话 我有类似的东西,但它不起作用

SELECT app_id,env,count(distinct session_id) as num_of_sessions,from_unixtime(timestamp/1000) as ts
FROM "sessions" 
where env='demo' and date(from_unixtime(timestamp/1000))>date_add('week',-1,(SELECT max(timestamp) FROM "sessions" where env='demo' limit 1))
group by app_id,from_unixtime(timestamp/1000)
order by from_unixtime(timestamp/1000)

我得到的错误

Error running query: Syntax_ERROR: line 3:58: Unexpected parameters (varchar(4),integer,bigint) for function date_add. Expected: date_add(varchar(x),bigint,date),date_add(varchar(x),time),time with time zone),timestamp),timestamp with time zone)

我从来没有在查询中做过查询,所以这可能是问题所在,但我不明白为什么

解决方法

错误很明显。

据我所知,会话表中的 timestamp 列是类型 bigint。事实上,它代表了一个 Unix 时间戳,这就是为什么要执行 from_unixtime(timestamp/1000)

但是在给您错误的 date_add 函数中,您只需执行仍然是 bigint 类型的 max(timestamp)

date_add func 需要第三个参数为 time 或日期 type,因此您必须像以前一样强制转换它,因此:

date_add('week',-1,(
   SELECT from_unixtime(max(timestamp) / 1000) 
   FROM "sessions" 
   WHERE env='demo' limit 1)
)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。