作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑以下示例数据
| SN | DateTime | Status |
|----|-----------------------|--------|
| 1 | '2015-01-01 00:30:00' | OPEN |
| 2 | '2015-01-01 00:35:00' | OPEN |
| 3 | '2015-01-01 00:40:00' | CLOSED |
| 4 | '2015-01-01 00:50:00' | OPEN |
| 5 | '2015-01-01 01:10:00' | OPEN |
| 6 | '2015-01-01 01:15:00' | CLOSED |
| 7 | '2015-01-01 01:20:00' | CLOSED |
| 8 | '2015-01-01 01:30:00' | OPEN |
| 9 | '2015-01-01 01:40:00' | OPEN |
| 10 | '2015-01-01 01:52:00' | OPEN |
| 11 | '2015-01-01 01:55:00' | CLOSED |
| 12 | '2015-01-01 02:15:00' | OPEN |
| 13 | '2015-01-01 02:30:00' | OPEN |
我需要选择“状态”列的值较之前的记录发生更改的记录。应始终返回第一条记录。
我可以使用 SQL Server 中的 For 循环来完成此操作,但我想要一个更好的解决方案。是否可以在单个 SELECT 语句中完成此操作?该查询应返回序列号为 1、3、4、6、8、11 和 12 的行。
最佳答案
您可以使用 LAG
获取之前的 Status
值,然后在外部查询的 WHERE
子句中使用该值来获取您想要的结果想要:
SELECT SN, [DateTime], Status
FROM (
SELECT SN, [DateTime], Status,
LAG(Status) OVER (ORDER BY [DateTime]) AS prevStatus
FROM mytable ) t
WHERE COALESCE(prevStatus, '') <> Status
关于sql-server - 仅根据一个字段选择与先前记录相比发生更改的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30474169/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!