從 datetime2 數據類型到 datetime 數據類型的轉換產生一個超出范圍的值


在ASP.NET MVC 使用 EF Code First 添加數據時遇到 從 datetime2 數據類型到 datetime 數據類型的轉換產生一個超出范圍的值 的問題,檢查了下數據表並沒有設置為datetime2 數據類型的字段

最后設斷點調試才發現問題所在,有一個datetime類型的字段設為了不可為空,code  first的實體類中是以DateTime為數據類型,默認值為0001-01-01 00:00:00.000,所以才會提示超出了范圍

datetime2和datetime的區別:

官方MSDN對於datetime2的說明:

定義結合了 24 小時制時間的日期。 可將 datetime2 視作現有 datetime 類型的擴展,其數據范圍更大,默認的小數精度更高,並具有可選的用戶定義的精度。

這里值的注意的是datetime2的日期范圍是"0001-01-01 到 9999-12-31"(公元元年 1 月 1 日到公元 9999 年 12 月 31 日)。

而datetime的日期范圍是:”1753 年 1 月 1 日到 9999 年 12 月 31 日“。這里的日期范圍就是造成“從 datetime2 數據類型到 datetime 數據類型的轉換產生一個超出范圍的值”這個錯誤的原因。

DateTime字段類型對應的時間格式是yyyy-MM-dd HH:mm:ss.fff,3個f,精確到1毫秒(ms),示例2014-12-0317:06:15.433。
 
DateTime2字段類型對應的時間格式是yyyy-MM-dd HH:mm:ss.fffffff,7個f,精確到0.1微秒(μs),示例2014-12-0317:23:19.2880929。
 
如果用SQL的日期函數進行賦值,DateTime字段類型要用GETDATE(),DateTime2字段類型要用SYSDATETIME()。

 

最簡單的解決辦法就是,給字段設置一個大於1753 年 1 月 1 日的初始值

 

原文地址:http://bkcoding.cn/post_1212.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM