sql >> Databasteknik >  >> RDS >> Sqlserver

Hur man ökar räknaren i select

Med en cte- och fönsterfunktion Row_Number()... Jag bör dock notera att det skulle vara bäst om du ersätter (Select NULL) i OVER-satsen med en korrekt sekvens (dvs. identitet int, datetime).

Declare @YourTable table (ColumnA int)
Insert Into @YourTable values (1),(0),(0),(0),(1),(0),(0),(0),(0),(1),(0),(1),(0),(0),(1),(0)

;with cte as (
    Select *,RN=Row_Number() over (Order By (Select Null)) from @YourTable
)
Select A.ColumnA
      ,ColumnB = sum(B.ColumnA)
 From  cte A
 Join  cte B on (B.RN<=A.RN)
 Group By A.ColumnA,A.RN
 Order By A.RN

Retur

ColumnA ColumnB
1       1
0       1
0       1
0       1
1       2
0       2
0       2
0       2
0       2
1       3
0       3    
1       4
0       4
0       4
1       5
0       5


  1. mysql INTE I QUERY optimera

  2. cakephp använder komponenter som kontrollermetoder

  3. Knee-Jerk Wait Statistik :CXPACKET

  4. Hur LÅT SOM fungerar i MariaDB