具有外键实体框架的复合键

时间:2015-05-28 08:22:03

标签: sql-server entity-framework

我有以下复合键:

表RolesInProject

ProjectRole PK和FK到ProjectRole

帐户PK和FK到帐户

ProjectID PK和FK到项目

我想检查某个帐户是否在项目中具有某个角色而不使用实体框架编写任何SQL。我怎样才能做到这一点? 我还希望能够使用实体框架更改/删除帐户的角色。

1 个答案:

答案 0 :(得分:1)

您可以查看:

if(dbContext.RolesInProject.Any(c=>c.ProjectRole == certainRole && 
                                   c.Account == certainAccount && 
                                   c.ProjectID == certainProject))
{
    DoSomething();
}
else
{
    DoSomethingElse();
}

要删除:

var item = dbContext.RolesInProject.FirstOrDefault(c=>c.ProjectRole == certainRole && 
                                                      c.Account == certainAccount && 
                                                      c.ProjectID == certainProject);

if(item != null)
{
    dbContext.RolesInProject.DeleteObject(item);
    dbContext.SaveChanges();
}

改变:

var item = dbContext.RolesInProject.FirstOrDefault(c=>c.ProjectRole == certainRole && 
                                                      c.Account == certainAccount && 
                                                      c.ProjectID == certainProject);

if(item != null)
{
    item.SomeColumn = someValue;
    dbContext.RolesInProject.ApplyChanges(item);
    dbContext.SaveChanges();
}