sql >> Base de Datos >  >> RDS >> Sqlserver

Entity Framework/SQL2008 - ¿Cómo actualizar automáticamente los campos LastModified para entidades?

Sé que llegué un poco tarde a la fiesta, pero acabo de resolver esto para un proyecto en el que estoy trabajando y pensé en compartir mi solución.

Primero, para que la solución sea más reutilizable, creé una clase base con las propiedades de marca de tiempo:

public class EntityBase
{
    public DateTime? CreatedDate { get; set; }
    public DateTime? LastModifiedDate { get; set; }
}

Luego anulé el método SaveChanges en mi 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();
    }
}