Я знаю, что есть несколько похожих постов, но я не могу найти ни одного с решением этой проблемы.
Я хочу добавить (своего рода) AudioLog при добавлении, изменении или удалении сущностей (мягкое удаление) в Entity Framework 6. Я переопределил SaveChanges, и поскольку я хочу добавить только записи журнала для EntityStates Added, Modified или Deleted, Я получаю список перед первым вызовом SaveChanges. Проблема в том, что, поскольку мне нужно регистрировать, какая операция была выполнена, мне нужно проверить EntityState сущностей. Но после вызова SaveChanges для всех записей EntityState не изменяется.
public override int SaveChanges()
{
using (var scope = new TransactionScope())
{
var modifiedEntries = ChangeTracker.Entries()
.Where(e => e.State == EntityState.Added || e.State == EntityState.Deleted || e.State == EntityState.Modified)
.ToList();
int changes = base.SaveChanges();
foreach (var entry in modifiedEntries)
{
ApplyAuditLog(entry);
}
base.SaveChanges();
scope.Complete();
return changes;
}
}
private void ApplyAuditLog(DbEntityEntry entry)
{
ILog entity = entry.Entity as ILog;
if (entity != null)
{
LogOperation operation;
switch (entry.State)
{
case EntityState.Added:
operation = LogOperation.CreateEntity;
break;
case EntityState.Deleted:
operation = LogOperation.DeleteEntity;
break;
case EntityState.Modified:
operation = LogOperation.UpdateEntity;
break;
default:
throw new ArgumentOutOfRangeException();
}
AuditLog log = new AuditLog
{
Created = DateTime.Now,
Entity = entry.Entity.GetType().Name,
EntityId = entity.Id,
Operation = operation,
};
AuditLog.Add(log);
}
}
SaveChanges()
, потому что до этого идентификатора просто не существовало. - person user2674389   schedule 06.11.2013