2014-04-14 36 views
1

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

回答

4

AddOrUpdate只添加或更新主要实体,但不添加或更新它的关系。

所以,你必须做的两个步骤:

  1. 创建RoleAddOrUpdate它。现在你可以得到RoleId(或任何PK)形成你添加或更新Role
  2. 创建Permissions,并明确设置其RoleId(或任何FK)。然后AddOrUpdatePermissions
+0

在这种情况下,权限和角色具有多对多的关系,所以我将不必使用AddOrUpdate单独更新它们,但这仍然可以回答问题。谢谢! – pquest