首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL领先/滞后智能解决方案

SQL领先/滞后智能解决方案
EN

Stack Overflow用户
提问于 2017-11-02 18:25:10
回答 1查看 314关注 0票数 0

我在一家仍然使用MS SQL Server2008 R2的公司工作,所以我不能使用领先/滞后功能。

我知道子查询的一般解决方法,使用分区等来复制它所做的事情,但我正在做的一个项目需要使用很多很多的引导和滞后。

因此,我的问题是,有没有人想出一种聪明的方法来复制可以从UDF等调用的引导函数,从而使这一过程变得更容易?

EN

回答 1

Stack Overflow用户

发布于 2017-11-02 18:30:28

在SQL Server2008中,您可以使用apply

代码语言:javascript
复制
select t.*, tprev.*
from t outer apply
     (select top 1 tprev.*
      from t tprev
      where tprev.? = t.? and   -- partitioning columns
            tprev.? < t.?       -- order by columns
      order by ? desc           -- order by columns, ordering reversed
     ) tprev;

这将替代1的滞后(类似的代码处理lead())。它可以同时处理多个列。本文涵盖了lag()的许多常见用法。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47072892

复制
相关文章

相似问题

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