Probleme mit der Genauigkeit von Datum und Uhrzeit in SQL Server
Beim Einfügen von Werten in Datetime-Spalten in SQL Server kann es zu unerwarteten Millisekundenverlusten kommen. Zum Beispiel die folgende Abfrage:
<code class="language-sql">BEGIN INSERT INTO TESTTABLE (IntField, BitField, StringField, DateField) VALUES ('1', 1, 'hello', {ts '2009-04-03 15:41:27.378'}); SELECT SCOPE_IDENTITY() END</code>
Bei anschließender Verwendung der SELECT * FROM TESTTABLE WITH (NOLOCK)
-Abfrage kann der Wert der DateField-Spalte wie folgt aussehen:
<code>2009-04-03 15:41:27.*377*</code>
Erklärung des Unterschieds in der Millisekundengenauigkeit
Dieser scheinbare Verlust von Millisekunden ist auf Speicherbeschränkungen von SQL Server zurückzuführen. Die Zeitgenauigkeit von SQL Server beträgt ungefähr 1/300 Sekunde, und diese Intervalle liegen immer bei 0, 3 und 7 Millisekunden. Daher wird im obigen Beispiel der Wert auf das nächste 3-Millisekunden-Intervall abgerundet, was zum beobachteten Suffix .377 führt.
Die Herausforderung der Millisekunden-Präzision meistern
Wenn die Genauigkeit im Millisekundenbereich entscheidend ist, gibt es keine einfache Lösung. Zu den vorgeschlagenen Lösungen gehören:
Während diese Methoden die Komplexität erhöhen, können sie die nötige Präzision bieten, wenn Millisekundengenauigkeit unbedingt erforderlich ist.
Das obige ist der detaillierte Inhalt vonWarum verliert SQL Server beim Einfügen von Datetime-Werten Millisekunden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!