sql >> Database >  >> RDS >> Sqlserver

Hoe de teller in select te verhogen

Met een cte- en vensterfunctie Row_Number()... Ik moet echter opmerken dat het het beste zou zijn als u (Select NULL) in de OVER-clausule vervangt door een juiste reeks (dwz identiteit 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

Retourneren

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. Hoe meerdere SQL-query's uitvoeren in MySQL Workbench?

  2. Kan ik de distributiemethode op een bestaande Citus-tabel wijzigen?

  3. mysql min waar statement

  4. OraclePreparedStatement gebruiken met DBCP-verbinding