SavingChanges 事件与 SaveChanges 覆盖之间的区别?

Difference between SavingChanges event vs SaveChanges override?

我已经阅读了多篇关于如何使用 entity framework 实现审计日志的文章。我目前在 DbContextSaveChanges 方法中嵌入了审计逻辑。请记住,下面的代码是一个 EF4/5 实现,我正准备更新到 EF6。

namespace Database {
    public class AuditDetails {
        public string RemoteHost { get; set; }
        public string RevisionUser { get; set; }
        public string RevisionNotes { get; set; }
        public DateTime RevisionDateTime { get; set; }
    }

    public class MyContext : DbContext {
        // ... Unrelated overrides here ... //
        public void SaveChanges(AuditDetails auditDetails) {
            var saveCount = ProcessConcurrency();
            var items = ChangeTracker.Entries<MyEntity>().ToList();
            if (saveCount <= 0 || items == null || !items.Any() || auditDetails == null) return;
            foreach (var item in items.Select(entityEntry => entityEntry.Entity).Where(i => i != null)) {
                // ... create audit log using AuditDetails values ... //
            }
            // ... and call base.SaveChanges() ... //
        }
    }
}

所以问题是:

总结:

我认为在大多数情况下这并不重要。我可以想到三种情况,需要两种选择之一:

  1. SaveChanges 应该被完全覆盖,所以 base.SaveChanges 不应该被调用:只有覆盖才能做到这一点。

  2. 另一个 class 涉及保存更改时发生的事情:只有事件可以做到这一点。 (或者也许我应该说:一个事件将是显而易见的选择模式)。

  3. 您想要选择性地扩展 SaveChanges。根据我的口味,通过某些参数在构造函数中激活事件比使用 if (option) 开始覆盖更清晰,其中 option 必须已存储为成员变量。

在所有其他情况下,我总是使用覆盖。该事件要求先挖出 ObjectContext(因为它是 ObjectContext.SavingChanges)。覆盖是硬连线的。事件订阅总是会在代码维护中以某种方式中断。