sql >> Base de Datos >  >> RDS >> Sqlserver

¿Por qué Datediff entre GETDATE() y SYSDATETIME() en milisegundos siempre es diferente?

Son dos llamadas de función diferentes que pueden devolver dos veces diferentes.

Además GETDATE devuelve un datetime tipo de datos que solo tiene una precisión de 3-4 ms mientras que SYSDATETIME() devuelve un datetime2(7) tipo de datos.

Incluso si ambas llamadas regresaran exactamente a la misma hora, podría ver el problema que está experimentando debido al redondeo.

DECLARE @D1 DATETIME2 = '2012-08-18 10:08:40.0650000'
DECLARE @D2 DATETIME = @D1 /*Rounded to 2012-08-18 10:08:40.067*/
SELECT DATEDIFF(ms, @D1 , @D2) /*Returns 2*/

La otra respuesta es incorrecta si sustituye en GETDATE() la función solo se llama una vez, como se puede demostrar a continuación.

WHILE DATEDIFF(ms, GETDATE() , GETDATE()) = 0 
PRINT 'This will not run in an infinite loop'

Al ejecutar un bucle en mi escritorio de Windows XP con GETDATE() y SYSDATETIME Sin embargo, también puedo ver resultados que indican que algo más podría estar sucediendo. Quizás llamando a una API diferente.

CREATE TABLE #DT2
  (
     [D1] [DATETIME2](7),
     [D2] [DATETIME2](7)
  )

GO

INSERT INTO #DT2
VALUES(Getdate(), Sysdatetime())

GO 100

SELECT DISTINCT [D1],
                [D2],
                Datediff(MS, [D1], [D2]) AS MS
FROM   #DT2

DROP TABLE #DT2 

Resultados de ejemplo a continuación

+-----------------------------+-----------------------------+-----+
|             D1              |             D2              | MS  |
+-----------------------------+-----------------------------+-----+
| 2012-08-18 10:16:03.2500000 | 2012-08-18 10:16:03.2501680 |   0 |
| 2012-08-18 10:16:03.2530000 | 2012-08-18 10:16:03.2501680 |  -3 |
| 2012-08-18 10:16:03.2570000 | 2012-08-18 10:16:03.2501680 |  -7 |
| 2012-08-18 10:16:03.2600000 | 2012-08-18 10:16:03.2501680 | -10 |
| 2012-08-18 10:16:03.2630000 | 2012-08-18 10:16:03.2501680 | -13 |
| 2012-08-18 10:16:03.2630000 | 2012-08-18 10:16:03.2657914 |   2 |
| 2012-08-18 10:16:03.2670000 | 2012-08-18 10:16:03.2657914 |  -2 |
| 2012-08-18 10:16:03.2700000 | 2012-08-18 10:16:03.2657914 |  -5 |
| 2012-08-18 10:16:03.2730000 | 2012-08-18 10:16:03.2657914 |  -8 |
| 2012-08-18 10:16:03.2770000 | 2012-08-18 10:16:03.2657914 | -12 |
| 2012-08-18 10:16:03.2800000 | 2012-08-18 10:16:03.2814148 |   1 |
+-----------------------------+-----------------------------+-----+

Las filas de interés son

| 2012-08-18 10:16:03.2600000 | 2012-08-18 10:16:03.2501680 | -10 |
| 2012-08-18 10:16:03.2630000 | 2012-08-18 10:16:03.2501680 | -13 |

Esta discrepancia es demasiado grande para ser un problema de redondeo y no puede ser solo un problema de tiempo con un retraso entre las llamadas a las dos funciones, ya que el problema existe en más de una fila que GETDATE informa 10:16:03.26X mientras que SYSDATETIME informa 10:16:03.250