繁体   English   中英

MySQL延迟/引导功能?

[英]MySQL lag/lead function?

我想计算用户开始时间和上次会话停止时间之间的差异。

表包含:用户数字,开始/停止unix时间戳。 它在用户和开始之后排序

user  start   stop
1    150000 150010
1    160011 160050
1    160100 160200
2    150011 150023
2    155001 155055
2    160001 160500
3    159001 159550

我期待结果看起来像:

user start   stop  diff
1   150000 150010  160011-150010=10001
1   160011 160050  160100-160050
1   160100 160200  0 (new user on next row)
2   150011 150023  155001-150023
2   155001 155055  160001-155055
2   160001 160500  0 (new user on next row)
3   159001 159550  and so on..

有可能这样做,如果是这样,怎么样?

这在应用程序级别上做得更好,但只是为了好玩,这里是在数据库级别:

select `user`, `start`, `stop`, diff from (
    select
    t.*
    , if(@prev_user = `user`, (`stop` - @prev) * -1, 0) as diff
    , @prev := `start`
    , @prev_user := `user`
    from
    t
    , (select @prev := null, @prev_user := null) var_init
    order by `user`, `start` desc
) sq
order by `user`, `start`

注意,MySQL中没有lag / lead函数。 你所能做的就是使用变量。 SELECT子句一次处理一行。 因此,您可以在SELECT子句的最后一行中分配当前行的值,因此将此变量用作SELECT子句第一行中“上一行”的值。
另请注意, ORDER BY非常重要。 表未排序。 除非您使用ORDER BY子句指定订单,否则不会对关系DBMS中的数据进行排序。

  • 阅读更多关于在查询中使用变量的信息

编辑:

将其更改为

UPDATE inactivitytmp
JOIN (
SELECT
inactivitytmp.*
, if(@prev_user_id = `user_id`, (`end_ts` - @prev) * -1, 0) as diff2
, @prev := `start_ts`
, @prev_user_id := `user_id`
FROM
inactivitytmp
, (SELECT @prev := null, @prev_user_id := null) var_init
ORDER BY `user_id`, `start_ts` DESC
) query_alias
ON inactivitytmp.user_id=query_alias.user_id AND inactivitytmp.start_ts=q uery_alias.start_ts AND inactivitytmp.end_ts=query_alias.end_ts
SET inactivitytmp.diff=query_alias.diff2;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM