我有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
在我的数据库中只有Id
和name
作为属性。
我的代码有什么问题,或者我的数据库中的任何设置是否必须更改?
提前致谢。
答案 0 :(得分:0)
这是因为我在一个db.SaveChanges();
中多次使用post
。减少使用db.SaveChanges
的时间有助于我摆脱错误。