Предположим, что следующий код обрабатывает событие SaveChanges объекта DataContext
void Context_SavingChanges(object sender, EventArgs e)
{
IEnumerable<ObjectStateEntry> objectStateEntries =
from ose in this.ObjectStateManager.GetObjectStateEntries(EntityState.Added | EntityState.Modified | EntityState.Deleted)
where ose.Entity != null
select ose;
foreach (ObjectStateEntry entry in objectStateEntries)
{
foreach (var field in entry.CurrentValues.DataRecordInfo.FieldMetadata)
{
var guid = Guid.NewGuid();
AuditEntry audit = AuditEntry.CreateAuditEntry(
id: guid,
entitySet: entry.EntitySet.Name,
typeName: entry.Entity.GetType().Name,
entityId: (entry.CurrentValues["Id"] as string) ?? ((entry.State == EntityState.Added) ? "New" : null),
oldValue: (entry.State != EntityState.Added) ? entry.OriginalValues[field.FieldType.Name].ToString() : "New",
newValue: (entry.State != EntityState.Deleted) ? entry.CurrentValues[field.FieldType.Name].ToString() : "Deleted",
modifier: Environment.UserDomainName + "\\" + Environment.UserName,
dbAction: Enum.GetName(typeof(EntityState), entry.State),
field: field.FieldType.Name,
dateStamp: DateTime.Now
);
this.AuditEntries.AddObject(audit);
}
}
}
Когда я создаю новый объект и пытаюсь сохранить его изменения, я получаю эту ошибку:
Невозможно вставить значение NULL в столбец «Id», таблица «TimeEF.dbo.AuditEntries»; столбец не допускает пустых значений. Вставить не удается.
Заявление было прекращено.
Когда, как вы видите, я установил Id, есть идеи? Ошибка?