目标是以一种方式扩展Entity Framework,以便对原始数据库的每个查询都可以对不同的DB进行具有相同数据的单独调用。
此行为的目的是跟踪特定数据库上的操作历史记录。历史记录将存储在其他数据库中,甚至可能存储在其他服务器中。
以EF扩展或使用特定EF配置的形式出现这种行为的可能性是什么?
EF DataContext被实现为部分类。您可以重写SaveChanges
以执行所需的操作(假设您的DataContext称为EfEntities):
public partial class EfEntities
{
public override int SaveChanges()
{
var changes = from e in this.ChangeTracker.Entries()
where e.State != System.Data.Entity.EntityState.Unchanged
select e;
foreach (var change in changes)
{
if (change.State == System.Data.Entity.EntityState.Added)
{
// Handle added entities
}
else if (change.State == System.Data.Entity.EntityState.Modified)
{
// Handle modified entities
var item = change.Cast<IEntity>().Entity;
var originalValues = this.Entry(item).OriginalValues;
var currentValues = this.Entry(item).CurrentValues;
foreach (string propertyName in originalValues.PropertyNames)
{
var original = originalValues[propertyName];
var current = currentValues[propertyName];
if (!Equals(original, current))
{
// log propertyName: original --> current
}
}
}
else if (change.State == System.Data.Entity.EntityState.Deleted)
{
// Handle deleted entities
}
}
return base.SaveChanges();
}
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句