Mengatasi Ralat Limpahan Aritmetik dengan DATEADD dan Bigints
Dalam menggunakan SQL untuk menukar tarikh JavaScript kepada tarikh SQL, kerumitan timbul apabila berurusan dengan yang terlalu besar data, yang membawa kepada pengecualian limpahan aritmetik. Untuk menangani isu ini, pertimbangkan penyataan SQL berikut:
DATEADD(MILLISECOND, cast(569337307200000 as bigint) % 1000, DATEADD(SECOND, cast(569337307200000 as bigint) / 1000, '19700101'))
Memecahkan DATEADD dalam dua peringkat, bermula dengan unit masa yang lebih besar seperti minit dan kemudian mengurangkan kepada milisaat yang dikehendaki, mengelakkan isu limpahan. Elakkan menggunakan bulan atau minggu kerana ini melibatkan pengiraan kalendar.
Sebagai contoh, pertimbangkan pengiraan masa mula berdasarkan tempoh arus yang besar dalam milisaat:
-- two-step process to prevent overflow -- subtract minutes (60000ms) as a first step -- then subtract the remaining milliseconds DATEADD(ms, -large_duration_ms%60000, DATEADD(minute, -large_duration_ms/60000, GETDATE()))
Dengan memecahkan DATEADD menjadi langkah yang lebih kecil, kami boleh mengendalikan nilai data yang besar dengan berkesan dan menyelesaikan ralat limpahan aritmetik.
Atas ialah kandungan terperinci Bagaimanakah Kita Boleh Mencegah Ralat Limpahan Aritmetik Apabila Menggunakan DATEADD dengan Nilai Milidetik Besar dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!