1

我有一个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 数据类型转换为 datetime 数据类型导致值超出范围。该语句已终止。

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

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

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

提前致谢。

4

1 回答 1

0

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

于 2012-05-15T07:23:23.617 回答