Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

SQL Server, за да преброи колко пъти дадена стойност се появява между няколко диапазона от дати и да сравни с предходни седмици

Мисля, че това може да ви даде това, което търсите:

;WITH 
weekcounts AS (
    SELECT Time_Stamp, Emp_ID, [Balance], ROUND(CONVERT(FLOAT,[Balance]) / 60.0,2) AS [Hours], DATEPART(week, Time_Stamp) AS int_week FROM newSampleData
)

,counts AS (
    SELECT Emp_ID, int_week, 1 AS int_count
    FROM weekcounts
    WHERE ([Hours] >= 7.5)
    UNION ALL
    SELECT weekcounts.Emp_ID, weekcounts.int_week, 1 AS int_count
    FROM weekcounts
        INNER JOIN counts
            ON weekcounts.Emp_ID = counts.Emp_ID
            AND (weekcounts.int_week - 1) = counts.int_week
            AND ([Hours] >= 7.5)
)

,countsagg AS (
    SELECT Emp_ID, int_week, SUM(int_count) AS int_count
    FROM counts
    GROUP BY Emp_ID, int_week
)

SELECT Emp_ID, 
       ISNULL([29],0) AS [week 29],
       ISNULL([30],0) AS [week 30],
       ISNULL([31],0) AS [week 31],
       ISNULL([32],0) AS [week 32],
       ISNULL([33],0) AS [week 33] 
FROM countsagg
PIVOT (MAX(int_count) FOR int_week IN ([29],[30],[31],[32],[33])) piv

Освен това, ако Balance е varchar, вие правите повече преобразувания, отколкото е необходимо в предоставения от вас код. Това ще даде резултат за часове с по-малко код:

ROUND(CONVERT(FLOAT,[Balance]) / 60.0,2)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Как да намерите разлика между два низа в SQL

  2. Запитване на SQL Server:Бързо с буквално, но бавно с променлива

  3. t-SQL съставен оператор причинява задънена улица, има ли идея защо?

  4. SQL 2012 - Заявка за връщане на номера на месеца

  5. Дублирани стойности в колона за самоличност