Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Entity Framework/SQL2008 - Como atualizar automaticamente os campos LastModified para Entidades?


Eu sei que estou um pouco atrasado para a festa, mas acabei de resolver isso para um projeto em que estou trabalhando e pensei em compartilhar minha solução.

Primeiro, para tornar a solução mais reutilizável, criei uma classe base com as propriedades timestamp:
public class EntityBase
{
    public DateTime? CreatedDate { get; set; }
    public DateTime? LastModifiedDate { get; set; }
}

Então eu substituí o método SaveChanges no meu DbContext:
public class MyContext : DbContext
{
    public override int SaveChanges()
    {
        ObjectContext context = ((IObjectContextAdapter)this).ObjectContext;

        //Find all Entities that are Added/Modified that inherit from my EntityBase
        IEnumerable<ObjectStateEntry> objectStateEntries =
            from e in context.ObjectStateManager.GetObjectStateEntries(EntityState.Added | EntityState.Modified)
            where
                e.IsRelationship == false &&
                e.Entity != null &&
                typeof(EntityBase).IsAssignableFrom(e.Entity.GetType())
            select e;

        var currentTime = DateTime.Now;

        foreach (var entry in objectStateEntries)
        {
            var entityBase = entry.Entity as EntityBase;

            if (entry.State == EntityState.Added)
            {
                entityBase.CreatedDate = currentTime;
            }

            entityBase.LastModifiedDate = currentTime;
        }

        return base.SaveChanges();
    }
}