在EF和MVC中使用SaveChanges时出现奇怪的错误消息

时间:2012-05-14 13:14:54

标签: database asp.net-mvc linq entity-framework entity-framework-4

我有dropdownlistfor的值不是来自我的数据库,当用户选择我的数据库中不存在的值时,我想将它保存到数据库中(如果它已经存在,我只需使用现有数据。)

这对我的一些数据工作正常(请参阅代码,了解它不起作用的地方)

这是我的存储库:

 public void newPerson(Person addperson)
    {
        db.Person.AddObject(addperson);
        db.SaveChanges(); //This wont work
    }

这是我的控制器:

[HttpPost]
    public ActionResult Create(CreateNKIphase1ViewModel model)
    {
        if (ModelState.IsValid)
        {
            var goalcard = new GoalCard();

            var companyChecker = "";
            var dbCompanies = createNKIRep.GetCustomerByName();
            var addcustomer = new Customer();
            foreach (var existingcustomer in dbCompanies)
            {
                companyChecker = existingcustomer.CompanyName;
                    if (existingcustomer.CompanyName == model.CompanyName)
                    {
                        var customerId = existingcustomer.Id;
                        var selectedCustomerID = createNKIRep.GetByCustomerID(customerId);
                        goalcard.Customer = selectedCustomerID;
                        break;
                    }
            }
            if (companyChecker != model.CompanyName)
            {
                addcustomer.CompanyName = model.CompanyName;
                createNKIRep.newCustomer(addcustomer); //This works!
                goalcard.Customer = addcustomer;
            }

            if (model.PersonName != null)
            {
                var Personchecker = "";
                var dbPersons = createNKIRep.GetPersonsByName();

                foreach (var existingPerson in dbPersons)
                {
                    Personchecker = existingPerson.Name;
                    if (existingPerson.Name == model.PersonName)
                    {
                        var personId = existingPerson.Id;
                        var selectedPersonID = createNKIRep.GetByPersonID(personId);
                        goalcard.Person = selectedPersonID;
                        break;
                    }
                }
                if (Personchecker != model.PersonName)
                {
                    Person newPerson = new Person();
                    newPerson.Name = model.PersonName;
                    createNKIRep.newPerson(newPerson);//Where repository is called
                    goalcard.Person = newPerson;
                }
            }

但是当我尝试保存新的Person时,我收到以下错误消息:

  

将datetime2数据类型转换为日期时间数据类型会导致超出范围的值。   声明已经终止。

     

描述:执行当前Web请求期间发生了未处理的异常。请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息。

即使Person在我的数据库中只有Idname作为属性。

我的代码有什么问题,或者我的数据库中的任何设置是否必须更改?

提前致谢。

1 个答案:

答案 0 :(得分:0)

这是因为我在一个db.SaveChanges();中多次使用post。减少使用db.SaveChanges的时间有助于我摆脱错误。