0

EF Code First を使用しているときにデータベースで行われた変更をリッスンするイベントが必要な場合、どうすればよいのでしょうか?

Update()ユーザーを追加するなど、データベースに変更が加えられた場合に発生するメソッドがある場合のように。

4

2 に答える 2

0
public MyContext() {
((IObjectContextAdapter)this).ObjectContext.SavingChanges += SavingChangesHandler;
}

private void SavingChangesHandler(object sender, EventArgs e) {

foreach (DbEntityEntry entry in ChangeTracker.Entries().Where(entry => entry.State == EntityState.Added || entry.State == EntityState.Modified || entry.State == EntityState.Deleted)) {
_log.DebugFormat("{0} Entity: {1}", entry.State.ToString(), entry.Entity.ToString().Contains("DynamicProxies") ? entry.Entity.GetType().BaseType.Name : entry.Entity.ToString());
if (entry.State != EntityState.Deleted) {
        var changedProperties = entry.CurrentValues.PropertyNames.Where(p => entry.Property(p).IsModified);
    changedProperties.ToList().ForEach(p => _log.DebugFormat("{0} changed from {1} to {2}", p, entry.Property(p).OriginalValue, entry.Property(p).CurrentValue));
    //TODO: handle complex properties
                }
            }
    }
于 2012-09-24T20:29:33.683 に答える
0

このhttp://dotnet.dzone.com/articles/c-sqldependency-monitoringについてどう思いますか

于 2012-09-24T16:13:58.440 に答える