sql >> Database teknologi >  >> RDS >> Sqlserver

Antal uger og delvise uger mellem to dage beregnet forkert

DATEDIFF tæller overgange , ikke punktum (se f.eks. DATEDIFF(year,'20161231','20170101') ). Den behandler også søndagen som den første dag i ugen. Så hvordan kompenserer vi for disse funktioner? For det første flytter vi vores datoer, så mandage er de nye søndage, og for det andet tilføjer vi 1 for at kompensere for hegnspost-fejlen:

declare @Samples table (
    StartAt date not null,
    EndAt date not null,
    SampleName varchar(93) not null
)
insert into @Samples (StartAt,EndAt,SampleName) values
('20170101','20170131','Question - 6'),
('20170102','20170129','Exactly 4'),
('20170102','20170125','3 and a bit, round to 4'),
('20170101','20170129','4 and 1 day, round to 5')
--DATEDIFF counts *transitions*, and always considers Sunday the first day of the week
--We subtract a day from each date so that we're effectively treating Monday as the first day of the week
--We also add one because DATEDIFF counts transitions but we want periods (FencePost/FencePanel)
select *,
    DATEDIFF(WEEK, DATEADD(day,-1,StartAt), DATEADD(day,-1,EndAt)) +1
    as NumWeeks
from @Samples

Resultater:

StartAt    EndAt      SampleName                 NumWeeks
---------- ---------- -------------------------- -----------
2017-01-01 2017-01-31 Question - 6               6
2017-01-02 2017-01-29 Exactly 4                  4
2017-01-02 2017-01-25 3 and a bit, round to 4    4
2017-01-01 2017-01-29 4 and 1 day, round to 5    5

Hvis dette ikke matcher, hvad du ønsker, kan du måske adoptere og tilpasse mine @Samples tabel for at vise de resultater, du forventer.



  1. SQL til HQL forespørgsel Grails

  2. IKKE DISTINCT-forespørgsel i mySQL

  3. Hvad er længden jeg skal angive for streng krypteret med AES-256-CBC i databasen?

  4. Hvordan opretter jeg en lagret procedure, der valgfrit vil søge i kolonner?