使用查找表查询多对多关系并返回符合条件的所有关系

时间:2014-05-28 14:19:24

标签: linq

表格如下:

Film有一个filmID

Film_actor_lookup有一个FilmID和一个ActorID

电影ActorActorID

Film_actor_lookup表用于解决电影和演员的多对多关系

我知道这段代码不太正确,不知道该去哪里。

public IEnumerable<Film> getAllFilms(Actor ActorName)
    {
         return(FilmEntity.Films.Where(A => A.Actors.Equals(ActorName)));
    }

这段代码是否符合我的需要并返回演员所在的所有电影?

1 个答案:

答案 0 :(得分:0)

return(Films.Where(f => f.Actors.Any(act=>act.Name == ActorName)));

您可以查找具有与该名称匹配的actor的Film。您应该能够直接查询Films

您也可以前往Actor

Actors.Where(act=>act.Name == ActorName).SelectMany(act=>act.Films).Distinct()