Entity Framework 更新数据库 datetime 类型的问题 从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值。...

 

从ado.net 的实体模型创建sql2008的数据库,日期类型为 datetime ,可是在代码里修改日期时,savechanges 就会抛出异常,异常信息为:

更新条目时出错。有关详细信息,请参见内部异常

 

查看内部异常信息为:

从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值

 

郁闷死啦,终于找到了微软的这个说明:

System.Datetime

CLR System.DateTime 类型的范围和精度大于 SQL Server DATETIME 类型,这是 DataContext.CreateDatabase 方法的默认类型映射。要避免与 DATETIME 范围之外的日期相关的异常,请使用 DATETIME2(从 Microsoft SQL Server 2008 开始可用)。DATETIME2 可以与 CLR System.DateTime 的范围和精度相匹配。

 

说明来自:http://msdn.microsoft.com/zh-cn/library/bb386947.aspx

 

修改数据库中的datetime 为 datetime2 后问题解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值