我正在尝试从另一个数据库插入数据,这段代码之前是可以正常工作的,但今天突然不行了。
以下是代码:
var itemMember = Db.Members.FirstOrDefault(p => p.Id == CurrentMember.Id);
var itemSelectedName = Db.Topics.FirstOrDefault(p => p.Id == TopicId);
var itemMap = Db.Reeves.FirstOrDefault(p=> p.Member.Id == CurrentMember.Id);
var itemReeve = Db.Reeves.FirstOrDefault(p => p.Member.Id == CurrentMember.Id);
var item = new Problem
{
Name = input.Name,
Text = input.Info,
Topic = itemSelectedName,
WhoIs = itemMember,
Province = itemMap.Province,
District = itemMap.District,
Town = itemMap.Town,
Reeve=itemReeve,
Created=DateTime.Now,
Solved = false,
Read=false
};
Db.Problems.Add(item);
Db.SaveChanges();
代码中没有空值,但是会抛出以下错误:
将datetime2数据类型转换为datetime数据类型时,结果超出范围。
我该怎么办?
还有这个错误出现了:
System.Data.Entity.Infrastructure.DbUpdateException: 保存未公开其关系的外键属性的实体时发生错误。由于无法将单个实体识别为异常源,因此EntityEntries属性将返回null。通过在实体类型中公开外键属性,可以更轻松地处理保存期间的异常。
但是就像我说的,它直到今天都可以正常工作 :/
这是视图模型:
[Display(Name = "Başlık"), Required, StringLength(50)]
public string Name { get; set; }
[Display(Name = "Bilgi")]
[UIHint("TinyMCE")]
public string Info { get; set; }
[Required(ErrorMessage = "Gerekli Alan")]
[Display(Name = "Konu")]
[UIHint("DropDownList")]
[AdditionalMetadata("DataController", "Problem")]
[AdditionalMetadata("DataAction", "ProblemDrop")]
public int? TopicId { get; set; }
这里是模型
public class Problem
{
public int Id { get; set; }
public string Name { get; set; }
public string Text { get; set; }
public short Sira { get; set; }
public DateTime Created { get; set; }
public virtual Topic Topic { get; set; }
public virtual Member WhoIs { get; set; }
public virtual Province Province { get; set; }
public virtual Town Town { get; set; }
public virtual District District { get; set; }
public virtual Reeve Reeve { get; set; }
public Boolean Solved { get; set; }
public DateTime SolvedDate { get; set; }
public virtual Member WhoSolved { get; set; }
public Boolean Read { get; set; }
}
解决方案:日期为空可能是问题的原因吗?
DateTime
属性? - user3559349SolvedDate
是DATETIME类型,只支持1753年至9999年的日期。如果你不为SolvedDate
设置一个值,那么默认值是1/1/0001
,超出了范围。你可以将数据库字段改为DATETIME2类型,但看起来它应该是可空的。 - user3559349