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

问题描述

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

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)
)