Ho una tabella in SQL Server che contiene la durata di un utente che lavora per lavori diversi. Devo calcolare il numero totale di esperienze per l'utente.T-SQL Calcola la durata in mesi tra diversi anni di intervalli
Declare @temp table(Id int, FromDate DATETIME, ToDate DATETIME)
INSERT INTO @temp (Id ,FromDate ,ToDate)
VALUES (1 , '2003-1-08 06:55:56' , '2005-5-08 06:55:56'),
(2 , '2000-10-08 06:55:56' , '2008-7-08 06:55:56'),
(3 , '2013-6-08 06:55:56' , '2015-1-08 06:55:56'),
(4 , '2006-4-08 06:55:56' , '2011-3-08 06:55:56')
SELECT * FROM @temp
Desidero calcolare il numero totale di esperienze;
Id FromDate ToDate Difference IN Months
===================================================
1 2003-01-08 2005-05-08 28
2 2000-10-08 2008-07-08 93
3 2013-06-08 2015-01-08 19
4 2006-04-08 2011-03-08 59
dopo aver rimosso gli anni sovrapposti come nel 2003-2005 coperti nel 2000-2008; Ho qualcosa di simile:
Id FromDate ToDate Difference IN Months
===================================================
1 2000-10-08 2011-03-08 125
2 2013-06-08 2015-01-08 19
Quindi la risposta sarebbe 125+19 = 144
mesi. Per favore aiutami a trovare una soluzione.
La porzione del giorno è sempre 8? E quindi non hai mai mesi parziali da considerare? –
Hai provato la funzione DATEDIFF? https://msdn.microsoft.com/en-us/library/ms189794.aspx – Vinnie
Qual è la versione di SQL Server? –