Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Entity Framework/SQL2008 - Come aggiornare automaticamente i campi LastModified per le entità?

So di essere un po' in ritardo per la festa, ma ho appena risolto il problema per un progetto su cui sto lavorando e ho pensato di condividere la mia soluzione.

Innanzitutto, per rendere la soluzione più riutilizzabile, ho creato una classe base con le proprietà timestamp:

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

Quindi ho sovrascritto il metodo SaveChanges sul mio 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();
    }
}