2

我有以下数据:

(1,'20120615 8:03:43 PM'),
(1,'20120615 8:03:43 PM'),
(1,'20120615 8:03:48 PM'),
(1,'20120615 8:03:53 PM'),
(0,'20120615 8:03:58 PM'),
(1,'20120615 8:04:03 PM'),
(1,'20120615 8:04:08 PM'),
(1,'20120615 8:04:13 PM'),
(1,'20120615 8:04:18 PM'),
(0,'20120615 8:04:23 PM'),
(1,'20120615 8:04:28 PM'),
(1,'20120615 8:04:33 PM');

我想要的结果是:

(1,'20120615 8:03:43 PM', 1),
(1,'20120615 8:03:43 PM', 1),
(1,'20120615 8:03:48 PM', 1),
(1,'20120615 8:03:53 PM', 1),
(0,'20120615 8:03:58 PM', 0),
(1,'20120615 8:04:03 PM', 2),
(1,'20120615 8:04:08 PM', 2),
(1,'20120615 8:04:13 PM', 2),
(1,'20120615 8:04:18 PM', 2),
(0,'20120615 8:04:23 PM', 0),
(1,'20120615 8:04:28 PM', 3),
(1,'20120615 8:04:33 PM', 3);

换句话说,我想对除 0 之外的数据进行分组,就像上面的顺序一样。

4

4 回答 4

4

这是想法。为每个组的开始位置创建一个标志。这确实1 - col1在您上面的数据中。然后取这个标志的累积和。对于不是 的值0,这是组。以下查询采用这种方法,使用相关子查询进行计算:

select t.col1, t.dt,
       (case when t.col1 = 0 then 0 else 1+grouping end)
from (select t.*,
             (select sum(1-col1)
              from t t2
              where t2.dt <= t.dt
             ) as grouping
      from t
     ) t;

在 SQL Server 2012 中,您可以使用累积和执行此操作:

select t.col1, t.dt,
       (case when col1 = 0 then 0
             else 1+sum(1 - col1) over (order by dt)
        end)
from t;
于 2013-07-25T10:33:47.807 回答
3

试试这个——

DDL:

DECLARE @temp TABLE (Col1 INT, Col2 DATETIME)

INSERT INTO @temp (Col1, Col2)
VALUES 
     (1,'20120615 8:03:43 PM'),
     (1,'20120615 8:03:43 PM'),
     (1,'20120615 8:03:48 PM'),
     (1,'20120615 8:03:53 PM'),
     (0,'20120615 8:03:58 PM'),
     (1,'20120615 8:04:03 PM'),
     (1,'20120615 8:04:08 PM'),
     (1,'20120615 8:04:13 PM'),
     (1,'20120615 8:04:18 PM'),
     (0,'20120615 8:04:23 PM'),
     (1,'20120615 8:04:28 PM'),
     (1,'20120615 8:04:33 PM')

询问:

;WITH cte AS 
(
     SELECT Col2, Col3 = ROW_NUMBER() OVER (ORDER BY Col2)
     FROM @temp t2
     WHERE t2.Col1 = 0
)
SELECT t.Col1, t.Col2, ISNULL(t2.Col3, 0) + t.Col1 
FROM @temp t
OUTER APPLY (
     SELECT TOP 1 Col2, Col3
     FROM cte t2
     WHERE t.Col2 > t2.Col2
          AND t.Col1 = 1
     ORDER BY t2.Col2 DESC
) t2

输出:

Col1        Col2                    Col3
----------- ----------------------- --------------------
1           2012-06-15 20:03:43.000 1
1           2012-06-15 20:03:43.000 1
1           2012-06-15 20:03:48.000 1
1           2012-06-15 20:03:53.000 1
0           2012-06-15 20:03:58.000 0
1           2012-06-15 20:04:03.000 2
1           2012-06-15 20:04:08.000 2
1           2012-06-15 20:04:13.000 2
1           2012-06-15 20:04:18.000 2
0           2012-06-15 20:04:23.000 0
1           2012-06-15 20:04:28.000 3
1           2012-06-15 20:04:33.000 3
于 2013-07-25T10:33:48.740 回答
2

相关子查询的另一个选项。此查询使用 COUNT 函数,而不是 @Gordon Linoff 建议的 MAX 函数

SELECT *, (
           SELECT CASE WHEN t1.IntCol = 0 THEN 0 ELSE COUNT(*) + 1 END
           FROM dbo.test139 t2
           WHERE t2.IntCol = 0
             AND t1.dateCol > t2.dateCol
           ) AS IntCol2
FROM dbo.test139 t1

见演示SQLFiddle

于 2013-07-25T11:16:38.343 回答
0

请试试这个,你需要更改一些列名和表名

DECLARE @TABLE_COUNT BIGINT
DECLARE @LOOP_COUNT BIGINT=0
DECLARE @COULMN_A INT
DECLARE @COULMN_B DATETIME
DECLARE @COUNTER BIGINT=1
DECLARE @NEWTABLE TABLE(COULMN_A INT,COLUMN_B DATETIME,COUNTER INT)
SELECT @TABLE_COUNT= COUNT(*) FROM TABLE

WHILE @LOOP_COUNT<@TABLE_COUNT
BEGIN
SELECT @COULMN_A=COLUMN_A,@COULMN_B=COLUMN_B FROM TABLE
IF @COULMN_A=0
SELECT @COUNTER=@COUNTER+1

INSERT INTO @NEWTABLE VALUES(@COULMN_A,@COULMN_B,@COUNTER)

SELECT @LOOP_COUNT=@LOOP_COUNT+1
END

SELECT * FROM @NEWTABLE

如果在理解上需要任何帮助,请麻烦我

希望这有效

问候阿舒托什·艾莉亚

于 2013-07-25T10:33:37.363 回答