问题描述
我在雅典娜的桌子比今天晚了一周,但它一直在追赶 所以我想创建一个查询,在最新时间戳前一周为我提供所有会话 我有类似的东西,但它不起作用
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)
)