Entity FrameWork 4.3 實體屬性為decimal時默認只保存2位小數


問題描述:當采用EF的DbContext保存decimal類型數據到數據庫,默認只會保存小數點后的前2位小數,其余均置0;例如保存101.182352152322,實際存到數據庫里的數據為101.180000000000;

解決方法:在創建項目DbContext時,重寫DbContext.OnModelCreating()方法;然后通過如下方法指定精度:

1 protected override void OnModelCreating(DbModelBuilder modelBuilder) 
2 { 
3     modelBuilder.Entity<Product>().Property(product => product.Price).HasPrecision(18, 12); 
4 } 

 

其他網絡資料參考:

http://stackoverflow.com/questions/3504660/entity-framework-code-first-decimal-precision

http://www.cnblogs.com/qouoww/archive/2012/01/01/2309577.html


免責聲明!

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



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