1

我在 EF6 Code First 项目中使用 EntityFramework.Plus 的审计功能。当我添加以下代码时:

public virtual DbSet<AuditEntry> AuditEntries { get; set; }

public virtual DbSet<AuditEntryProperty> AuditEntryProperties { get; set; }

static EntityContext()
   {
            AuditManager.DefaultConfiguration.AutoSavePreAction = (context, audit) =>
            {
                var Entities = context as EntityContext;
                if (Entities != null)
                {
                    Entities.AuditEntries.AddRange(audit.Entries);
                }
                else throw new InvalidOperationException($"Context is null for {context.Database.Connection}");
            };
        }

我收到以下错误:

在模型生成期间检测到一个或多个验证错误:\r\n\r\nWebsite.Core.Entities.Audit: : EntityType 'Audit' 没有定义键。定义此 EntityType 的键。\r\nAudits: EntityType: EntitySet 'Audits' 基于没有定义键的类型 'Audit'。\r\n", "exceptionType": "System.Data.Entity.ModelConfiguration。模型验证异常”

审计不是我项目中的实体-如错误所述。当我删除上面的代码时,这个错误就被删除了。

任何人都可以帮忙吗?是否可以禁止外部库类型的模型验证?

提前致谢

HS

4

1 回答 1

2

免责声明:我是Entity Framework Plus的所有者

查看错误:

EntityType 'Audit' 没有定义键

看来您还映射了不应映射的 Audit 实体。

如果您有与此类似的行,请查看您的 EntityContext 并将其删除:

public virtual DbSet<Audit> Audits { get; set; }

回答子问题

我们的库中有 Audit 类,但要让它出现在上下文中,它应该被映射(我们不想要)。调试这个问题非常困难,因为你是唯一一个得到它的人。

您可以在新项目和当前项目中尝试以下代码吗?在这两种情况下,它都应该可以正常工作。

如果可以,请尝试提供更多信息以让我们重现此问题。

using System;
using System.Data.Entity;
using System.Windows.Forms;

namespace Z.EntityFramework.Plus.Lab
{
    public partial class Form_Issue_Audit_HeySatan : Form
    {
        public Form_Issue_Audit_HeySatan()
        {
            InitializeComponent();

            using (var ctx = new EntityContext())
            {
                var audit = new Audit();

                ctx.EntitySimples.Add(new EntitySimple {ColumnInt = 1});

                ctx.SaveChanges(audit);
            }
        }

        public class EntityContext : DbContext
        {
            static EntityContext()
            {
                AuditManager.DefaultConfiguration.AutoSavePreAction = (context, audit) =>
                {
                    var Entities = context as EntityContext;
                    if (Entities != null)
                    {
                        Entities.AuditEntries.AddRange(audit.Entries);
                    }
                    else throw new InvalidOperationException($"Context is null for {context.Database.Connection}");
                };
            }

            public EntityContext() : base("CodeFirstEntities")
            {
            }

            public DbSet<EntitySimple> EntitySimples { get; set; }
            public virtual DbSet<AuditEntry> AuditEntries { get; set; }
            public virtual DbSet<AuditEntryProperty> AuditEntryProperties { get; set; }

            protected override void OnModelCreating(DbModelBuilder modelBuilder)
            {
                modelBuilder.Types().Configure(x => x.ToTable(GetType().DeclaringType != null ? GetType().DeclaringType.FullName.Replace(".", "_") + "_" + x.ClrType.Name : ""));

                base.OnModelCreating(modelBuilder);
            }
        }

        public class EntitySimple
        {
            public int Id { get; set; }
            public int? ColumnInt { get; set; }
        }
    }
}
于 2016-12-06T22:40:55.923 回答