6

如何更改自动生成的多对多表的命名约定?

假设我有两个类:

public class User
{
    public int UserId { get; set; }
    public virtual List<Role> Roles { get; set; }
}

public class Role
{
    public int RoleId { get; set; }
    public virtual List<User> Users { get; set; }
}

默认情况下,这将创建一个名为UserRoles的表。

我可以将该表的名称更改为UsersInRoles 例如,通过在我的 DbContext 的 OnModelCreating 覆盖中使用以下内容:

modelBuilder.Entity<User>()
    .HasMany(p => p.Roles)
    .WithMany(p => p.Users)
    .Map(mc =>
    {
        mc.MapLeftKey("UserId");
        mc.MapRightKey("RoleId");
        mc.ToTable("UsersInRoles");
    });

但是,我真正想做的是更改命名约定,以便默认情况下,所有自动生成的多对多表都使用这个新约定。我无法弄清楚如何做到这一点,或者是否有可能。我不喜欢每次指定其中一种关系时都必须指定 9 行额外代码。

我目前使用的是 EF 版本 6.0.0-rc1。

4

1 回答 1

5

在发布之前,控制关系的能力已从基本约定 API 中删除,因为它不处于可用状态。您可以通过基于模型的约定访问模型中的所有属性和表。此处提供了基于模型的约定的概述:http: //msdn.microsoft.com/en-US/data/dn469439

此解决方案涉及在元数据 API 中进行更多挖掘,EntitySet 是此场景的正确类型

此约定应重命名生成的关系表:

public class MyConvention : IStoreModelConvention<EntitySet>
{
    public void Apply(EntitySet set, DbModel model)
    {
        var properties = set.ElementType.Properties;
        if (properties.Count == 2)
        {
            var relationEnds = new List<string>();
            int i = 0;
            foreach (var metadataProperty in properties)
            {
                if (metadataProperty.Name.EndsWith("_ID"))
                {
                    var name = metadataProperty.Name;
                    relationEnds.Add(name.Substring(0, name.Length - 3));
                    i++;
                }
            }
            if (relationEnds.Count == 2)
            {
                set.Table = relationEnds.ElementAt(0) + "_" + relationEnds.ElementAt(1) + "_RelationTable";
            }
        }
    }
于 2013-10-09T21:37:40.417 回答