J'ai des données dans un tableau avec des dates, et je veux compter les lignes par "Semaine de" (par exemple, "Semaine de 2017-05- 01 "), où le résultat a la date de la semaine (commençant le lundi) et le nombre de lignes correspondantes — même s'il n'y a pas de lignes pour cette semaine. (Tout cela va être dans une plage de dates.)Obtenir des données dans des groupes de "Semaine de ..." lorsque les dates peuvent être manquantes
je peux diviser les choses en semaines assez facilement par le regroupement sur DATEPART(wk, D)
(où D
est la colonne de date), mais je suis aux prises avec:
Comment obtenir la « semaine de la » date et remplir et
Comment une ligne pour une semaine où il n'y a pas de lignes de correspondance dans les données
VOICI regroupement par semaine:
SET DATEFORMAT ymd;
SET DATEFIRST 1; -- Monday is first day of week
DECLARE @startDate DATETIME = '2017-05-01';
DECLARE @endDate DATETIME = '2017-07-01';
SELECT DATEPART(wk, D) AS [Week Number], COUNT(*) AS [Count]
FROM #temp
GROUP BY DATEPART(wk, D)
ORDER BY DATEPART(wk, D);
Ce qui me donne:
+−−−−−−−−−−−−−+−−−−−−−+ | Week Number | Count | +−−−−−−−−−−−−−+−−−−−−−+ | 19 | 5 | | 20 | 19 | | 22 | 8 | | 23 | 10 | | 24 | 5 | | 26 | 4 | +−−−−−−−−−−−−−+−−−−−−−+
Mais idéalement, je veux:
+−−−−−−−−−−−−+−−−−−−−+ | Week | Count | +−−−−−−−−−−−−+−−−−−−−+ | 2017-05-01 | 5 | | 2017-05-08 | 19 | | 2017-05-15 | 0 | | 2017-05-22 | 8 | | 2017-05-29 | 10 | | 2017-06-05 | 5 | | 2017-06-12 | 0 | | 2017-06-19 | 4 | | 2017-06-26 | 0 | +−−−−−−−−−−−−+−−−−−−−+
Comment puis-je faire cela?
Configurer les informations pour les tests:
SET DATEFIRST 1;
SET DATEFORMAT ymd;
CREATE TABLE #temp (
D DATETIME
);
GO
INSERT INTO #temp (D)
VALUES -- Week of 2017-05-01 (#19)
('2017-05-01'),('2017-05-01'),('2017-05-01'),
('2017-05-06'),('2017-05-06'),
-- Week of 2017-05-08 (#20) - note no data actually on the 8th
('2017-05-10'),
('2017-05-11'),('2017-05-11'),('2017-05-11'),('2017-05-11'),('2017-05-11'),('2017-05-11'),
('2017-05-12'),('2017-05-12'),('2017-05-12'),('2017-05-12'),
('2017-05-13'),('2017-05-13'),('2017-05-13'),('2017-05-13'),('2017-05-13'),('2017-05-13'),('2017-05-13'),
('2017-05-14'),
-- Week of 2017-05-15 (#21)
-- (note we have no data for this week)
-- Week of 2017-05-22 (#22)
('2017-05-22'),('2017-05-22'),('2017-05-22'),
('2017-05-23'),('2017-05-23'),('2017-05-23'),('2017-05-23'),('2017-05-23'),
-- Week of 2017-05-29 (#23)
('2017-05-29'),('2017-05-29'),('2017-05-29'),
('2017-06-02'),('2017-06-02'),
('2017-06-03'),
('2017-06-04'),('2017-06-04'),('2017-06-04'),('2017-06-04'),
-- Week of 2017-06-05 (#24) - note no data actually on the 5th
('2017-06-08'),('2017-06-08'),('2017-06-08'),
('2017-06-11'),('2017-06-11'),
-- Week of 2017-06-12 (#25)
-- (note we have no data for this week)
-- Week of 2017-06-19 (#26)
('2017-06-19'),('2017-06-19'),('2017-06-19'),
('2017-06-20');
GO