SqlDateTime meluap. Harus antara 1/1/1753 12:00:00 AM dan 12/31/9999 11
Saat menyisipkan data dengan kerangka kerja NHibernate orm, kesalahan di atas dilaporkan:
Luapan SqlDateTime / Luapan SqlDateTime [Ringkasan: Kesalahan - SqlDateTime meluap. Harus antara 1/1/1753 12:00:00 AM dan 12/31/9999 PM SqlDateTime overflow. Harus antara 1/1/1753 12:00:00 Perang 31/12/9999 23:59:59 Alasan Saat menerapkan C# sisipkan atau perbarui database, kata tanggalwaktu]
Kesalahan - SqlDateTime meluap. Harus antara 1/1/1753 12:00:00 AM dan 12/31/9999 11:59:59 PM SqlDateTime meluap. Harus antara 1/1/1753 12:00:00 AM dan 12/31/9999 11:59:59 PM
Penyebab
Saat menggunakan C# sisipkan atau perbarui database, nilai bidang tanggalwaktu adalah null secara default penyisipan C# 0001-01-01 menyebabkan luapan tipe datetime server sql.
Rentang jenis DateTime di C#
DateTime.MinValue = 1/1/0001 12:00:00 AM DateTime.MaxValue = 23:59:59.99999999, 31 Desember 9999, tepat satu centang 100 nanodetik sebelum 00:00:00, 1 Januari 10000 Rentang jenis tanggalwaktu di SQL Server
antara 1/1/1753 12:00:00 dan 31/12/9999 23:59:59
Setelah membaca artikel ini, saya mungkin mengerti sesuatu, seharusnya ada properti yang kosong, NHibernate secara otomatis mengatur nilai default, saya pikir seharusnya seperti ini????
Kemudian, setelah menetapkan atribut UpdateTime yang awalnya tidak ditetapkan,menemukan bahwa tidak ada kesalahan, lalu masukkan tabel data,
Namun, bidang saya bisa kosong, apa yang harus saya lakukan???
Temukan properti UpdateTime di bawah kelas DateTime dan atur ke DateTime? Artinya, biarkan kekosongan. (Dalam xml yang dipetakan adalah yang terbaik, juga diatur ke not-null="false", sebagai berikut:)
Terakhir, sukses, ambil tangkapan layar database!
|