semana operaciones obtener hora fechas español ejemplos datepart convert con tsql date datediff

tsql - operaciones - obtener hora sql server



¿Es posible establecer el inicio de la semana para la función DATEDIFF de T-SQL? (1)

Sí, es posible

SET DATEFIRST 1; -- Monday

desde http://msdn.microsoft.com/en-us/library/ms181598.aspx

Parece que dataiff no respeta la Datefirst, así que hazlo así, ejecútalo así

create table #testDates (id int identity(1,1), dateAdded datetime) insert into #testDates values (''2009-07-09 15:41:39.510'') -- thu insert into #testDates values (''2009-07-06 15:41:39.510'') -- mon insert into #testDates values (''2009-07-05 15:41:39.510'') -- sun insert into #testDates values (''2009-07-04 15:41:39.510'') -- sat SET DATEFIRST 7 -- Sunday (Default select * from #testdates where datediff(ww, DATEADD(dd,-@@datefirst,dateadded), DATEADD(dd,-@@datefirst,getdate())) = 0 SET DATEFIRST 1 -- Monday select * from #testdates where datediff(ww, DATEADD(dd,-@@datefirst,dateadded), DATEADD(dd,-@@datefirst,getdate())) = 0

Robado de

http://social.msdn.microsoft.com/Forums/en-US/transactsql/thread/8cc3493a-7ae5-4759-ab2a-e7683165320b

Utilizo la función DATEDIFF para filtrar los registros agregados esta semana solamente:

DATEDIFF(week, DateCreated, GETDATE()) = 0

y noté lo que se supone que la semana comienza el domingo. Pero en mi caso, preferiría comenzar la semana del lunes. ¿Es posible de alguna manera en T-SQL?

¡Gracias!

Actualizar:

A continuación se muestra un ejemplo que muestra lo que DATEDIFF no verifica la variable @@ DATEFIRST , así que necesito otra solución.

SET DATEFIRST 1; SELECT DateCreated, DATEDIFF(week, DateCreated, CAST(''20090725'' AS DATETIME)) AS D25, DATEDIFF(week, DateCreated, CAST(''20090726'' AS DATETIME)) AS D26 FROM ( SELECT CAST(''20090724'' AS DATETIME) AS DateCreated UNION SELECT CAST(''20090725'' AS DATETIME) AS DateCreated ) AS T

Salida:

DateCreated D25 D26 ----------------------- ----------- ----------- 2009-07-24 00:00:00.000 0 1 2009-07-25 00:00:00.000 0 1 (2 row(s) affected)

26 de julio de 2009 es domingo, y quiero DATEDIFF devuelve 0 en la tercera columna también.