sql >> Databáze >  >> RDS >> Sqlserver

Jak zvýšit počítadlo ve výběru

S funkcí cte a okna Row_Number()... Měl bych však poznamenat, že by bylo nejlepší, kdybyste (Select NULL) v klauzuli OVER nahradili správnou sekvencí (tj. identity 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

Vrátí

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. Význam údržby na MSDB

  2. Prohlášení o stavu - Php Mysqli

  3. Vytvoření pole z tabulky MySQL

  4. Online vs offline zálohování