DbContext中获取修改Entity,生成修改数据的List

在DbContext的ChangeTracker中,可以通过Entries方法获取所有修改的数据,然后形成一个数据的List, 方法如下

 public static class ContextHelper
    {
        public static IEnumerable<DbEntityEntry> GetChangedEntries(this DbContext context)
        {
            return context.ChangeTracker.Entries()
                .Where(c => c.State == EntityState.Added || c.State == EntityState.Deleted ||
                            c.State == EntityState.Modified)
                .ToList();
        }

        public static DatabaseChange SerializeChangedEntry(this DbEntityEntry entry, IUser usr = null)
        {
            DatabaseChange result = null;
            var time = DateTime.Now;

            if (entry.State == EntityState.Added)
            {
                result = new DatabaseChange
                {
                    Id = Guid.NewGuid().ToString(),
                    DateTime = time,
                    Ip = usr?.IP,
                    User = usr?.UserName,
                    Table = GetTableName(entry.Entity.GetType()),
                    Action = "Add",
                    OriginalValues = string.Empty,
                    CurrentValues = entry.CurrentValues.ToJson(),
                };
            }

            if (entry.State == EntityState.Deleted)
            {
                result = new DatabaseChange
                {
                    Id = Guid.NewGuid().ToString(),
                    DateTime = time,
                    Ip = usr?.IP,
                    User = usr?.UserName,
                    Table = GetTableName(entry.Entity.GetType()),
                    Action = "Delete",
                    OriginalValues = entry.OriginalValues.ToJson(),
                    CurrentValues = String.Empty
                };
            }

            if (entry.State == EntityState.Modified)
            {
                result = new DatabaseChange
                {
                    Id = Guid.NewGuid().ToString(),
                    DateTime = time,
                    Ip = usr?.IP,
                    User = usr?.UserName,
                    Table = GetTableName(entry.Entity.GetType()),
                    Action = "Modify",
                    OriginalValues = entry.OriginalValues.ToJson(),
                    CurrentValues = entry.CurrentValues.ToJson()
                };
            }

            return result;
        }

        public static string GetTableName(Type type)
        {
            return ObjectContext.GetObjectType(type).Name;
        }

        public static IList<DatabaseChange> GetChanges(this DbContext context)
        {
            return context.GetChangedEntries()
                .Select(c => c.SerializeChangedEntry())
                .Where(c=>c!=null)
                .ToList();
        }

}

 

其中,定义DatabaseChange如下

  public class DatabaseChange
    {
        public string Id { get; set; }
        public DateTime DateTime { get; set; }
        public string Ip { get; set; }
        public string User { get; set; }
        public string Table { get; set; }
        public string Action { get; set; }
        public string OriginalValues { get; set; }
        public string CurrentValues { get; set; }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值