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


  1. 給這些字段一個值(不管它是否在數據庫設置了默認值),並且日期要大於1753年1月1日,這是最簡單的方法。
  2. 將數據庫類型修改為datetime?類型,也就是說允許為空。
  3. 修改數據庫字段類型為datetime2類型,前提是數據庫要支持該類型。
  4. 在C#中用new DateTime(year,month,day,hour,minute,second)來限制精度,原因之后會在datetime2和datetime的區別中提到。
  5. 這個方法不太推薦,將model的edmx中的providerManifestToken設置成2005,這樣ef就默認轉化成datetime。

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()。

 


免責聲明!

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



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