0

我在强类型 DbContext 的 OnModelCreating() 方法中指定了我自己的数据库表名和模式,如下所示:

modelBuilder.Entity<MyAssociativeClass>().ToTable("MYASSOCIATIVECLASS", schemaName: "MYSCHEMA");
        modelBuilder.Entity<MyAssociativeClass>()
            .HasKey(x => new { x.ClassA.ID, ClassBID = x.ClassB.ID });

但是,我收到以下错误:

属性表达式 'x => new <>f__AnonymousType1`2(ID = x.MyClassA.ID, MyClassBID = x.MyClassB.ID)' 无效。该表达式应表示一个属性:C#: 't => t.MyProperty' VB.Net: 'Function(t) t.MyProperty'。指定多个属性时使用匿名类型:C#: 't => new { t.MyProperty1, t.MyProperty2 }' VB.Net: 'Function(t) New From { t.MyProperty1, t.MyProperty2 }'。

如您所见,MyClassA 和 MyClassB 都有一个 ID 属性。我在匿名类型中为 MyClassB.ID 指定了一个不同的名称,因此两次使用相同的属性名称不会发生冲突。但这仍然会导致问题。为什么不允许这样做?

4

1 回答 1

1

我认为您的班级 MyAssociativeClass 将不得不将外键公开为属性,这样您就可以这样做:

modelBuilder.Entity<MyAssociativeClass>().ToTable("MYASSOCIATIVECLASS", schemaName: "MYSCHEMA");
        modelBuilder.Entity<MyAssociativeClass>()
            .HasKey(x => new { x.ClassA_Id, ClassB_Id});
于 2012-12-16T20:19:54.643 回答