AddOrUpdate不会修改子项

时间:2014-04-14 18:44:57

标签: c# .net entity-framework entity-framework-6

我在种子方法中使用AddOrUpdate来保持我的权限是最新的,但是,在下面的代码更新现有角色(而不是创建它)的情况下,我创建的任何新权限都没有被添加到角色。我做错了什么?

foreach (KeyValuePair<string, string[]> s in new Dictionary<string, string[]>{
                {"Superuser", context.Permissions.Select<Permission, string>(p=>p.Name).ToArray()},

            })
            {
                Role r = new Role();
                r.Name = s.Key;
                r.Permissions = new List<Permission>();
                foreach (string p in s.Value)
                    r.Permissions.Add(context.Permissions.Where(per => per.Name == p).First());

                context.Roles.AddOrUpdate(i => i.Name, r);
            }

context.SaveChanges();

1 个答案:

答案 0 :(得分:6)

AddOrUpdate仅添加或更新主要实体,而不是其关系。

所以你必须分两步完成:

  1. 创建RoleAddOrUpdate。现在,您可以从添加或更新的RoleId中获取Role(或PK的任何内容)。
  2. 创建Permissions,并明确设置RoleId(或任何FK)。然后AddOrUpdate Permissions