sql-server – 如何减去sql中的上一行?
发布时间:2020-12-12 08:53:31 所属栏目:MsSql教程 来源:网络整理
导读:如果我想将当前行减去上一行,我该怎么查询?我将在vb6循环中使用它. 这样的东西: Row12345 在第一个循环值1将不被扣除,因为它没有上一行,这是确定. 然后,下一个循环值2将被前一行值1扣除.直到最后一行. 如何实现这个例程? 通过SQL查询或VB6代码.Any会做. 解
如果我想将当前行减去上一行,我该怎么查询?我将在vb6循环中使用它.
这样的东西: Row 1 2 3 4 5 在第一个循环值1将不被扣除,因为它没有上一行,这是确定. 如何实现这个例程? 解决方法假设你有一个排序列 – 说id,那么你可以在SQL Server 2012中执行以下操作:select col,col - coalesce(lag(col) over (order by id),0) as diff from t; 在早期版本的SQL Server中,您可以使用相关的子查询做几乎相同的事情: select col,col - isnull((select top 1 col from t t2 where t2.id < t.id order by id desc ),0) from t 这使用isnull()而不是coalesce(),因为SQL Server中的“错误”,使用coalesce()来评估第一个参数两次. 您也可以使用row_number(): with cte as ( select col,row_number() over (order by id) as seqnum from t ) select t.col,t.col - coalesce(tprev.col,0) as diff from t left outer join t tprev on t.seqnum = tprev.seqnum + 1; 所有这些假定您有一些列来指定排序.它可能是一个id,或者创建日期或其他东西. SQL表本身是无序的,所以没有一列指定排序的“上一行”就没有这样的东西. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQLServer挂起的解决方法
- SQL Server不处理NText,Text,Xml或Image数据类型的比较
- 如何构造一个查询,只给出与T-SQL中的CSV列表中的所有值匹配
- Read Committed Snapshot和Snapshot Isolation
- PHP版Mysql爆破小脚本
- TD 安装遇到的问题与使用TD时遇到的问题
- 在 Windows服务器中启用/禁用SMBv1、SMBv2和SMBv3的方法
- 自动增加sql-server中的非标识列
- sql-server – 查找最大值并显示SQL Server中不同字段的相应
- sql-server – AcquireConnection方法调用连接管理器失败,错