【发布时间】:2015-01-21 07:59:40
【问题描述】:
将 datetime2 数据类型转换为 datetime 数据类型导致值超出范围。
我的应用程序最近开始显示此错误,这很奇怪,因为它之前工作过。我没有更改“Word”模型中与 DateTime 相关的任何内容。当我将新模型添加到我的项目中时,它就开始发生了。
当我尝试编辑数据时出现服务器错误。创建和删除工作正常。
控制器:
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit([Bind(Include = "ID,UsersLanguage,OtherLanguage,Notes")] Word word, int idOfCollection)
{
if (ModelState.IsValid)
{
db.Entry(word).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index", new { idOfCollection = idOfCollection });
}
return View(word);
}
型号:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Web;
namespace WebLanguageTeacher.Models.MyDatabase
{
public class Word
{
public int ID { get; set; }
[MinLength(2, ErrorMessage = "Wydaje mi się, że słowo powinno mieć przynajmniej 2 litery ;)")]
[DisplayName("Język Użytkownika")]
[Required]
public string UsersLanguage { get; set; }
[MinLength(2, ErrorMessage = "Wydaje mi się, że słowo powinno mieć przynajmniej 2 litery ;)")]
[DisplayName("Inny język")]
[Required]
public string OtherLanguage { get; set; }
[DisplayName("Notatki")]
public string Notes { get; set; }
[DisplayName("Ostatnia powtórka")]
public DateTime LastReviewed { get; set; }
[DisplayName("Następna powtórka")]
public DateTime NextReview { get; set; }
[DefaultValue(0)]
[DisplayName("Przerwa między powtórkami")]
public int ReviewInterval { get; set; } /*W miejsce Difficulty*/
[DisplayName("Nazwa właściciela")]
public string OwnerName { get; set; }
public virtual Collection Collection { get; set; }
[NotMapped]
public bool ModifyReview { get; set; } /* Klient przesyła tylko za ile dni będzie następna powtórka, serwer sam generuje datę*/
public Word(){
ModifyReview = false;
}
}
}
怎么了?我没有创建任何 DateTime2 变量,为什么我的应用会尝试将 DateTime2 转换为 DateTime?
我将 ASP.net MVC 与 EntityFramework 一起使用。
【问题讨论】:
-
调用
SaveChanges()之前LastReviewed和NextReview的实际值是多少? -
某些日期时间字段在数据库中可以为空?
-
@azhar_SE_nextbridge:不,这些文件都不能为空
-
可能您的一个或多个
DateTime值的值超出了SQL DATETIME 变量的范围(例如:如果它的默认值为DateTime.MinValue)。尝试使用调试器单步执行并检查 LastReviewed / NextReview 的值。
标签: c# asp.net-mvc entity-framework