1

我有 2 种类型的数据库结构,如下所示:

Project
     ProjectID
     ProjectName

Task
     TaskID
     TaskTitle
     Status
     ProjectID

由于在 sql server 上声明的所有关系 - dbml 自动知道它们,我可以简单地通过以下方式获取所有项目的任务:

myProject.Tasks

到目前为止,一切都很好。

我想显示所有项目及其任务,以便用户可以按状态过滤它们。这意味着我只想显示那些满足所选标准的任务(当然还有他们的项目)。

为此,我有一个中继器,看起来有点像这样:

<asp:Repeater id="rptProjects" runat="server">
      <ItemTemplate>
          <%# Eval("ProjectName") %> (<%# Eval("ProjectID") %>):
                  <asp:Repeater id="rptTasks" DataSource="<%#(Container.DataItem as Project).Tasks %>" runat="server">                          
                      <ItemTemplate>
                          <%# Eval("TaskTitle") %>
                      </ItemTemplate>
                  </asp:Repeater>
      </ItemTemplate>
</asp:Repeater>

但我无法弄清楚所需的 LINQ 查询。

在我尝试的每个查询中,我的项目都很好(这意味着如果项目的任务都不符合选定的标准,它不在列表中),但每次都Project.Tasks保留选定项目的所有任务,而不是过滤任务列表。

4

2 回答 2

2

您不仅需要过滤可查询的项目本身,还需要将Tasks关系投影到具有给定条件的新关系:

var query = context.Projects.Where(project => 
        project.Tasks.Any(task => task.Status == someStatus)
    .Select(project => new
    {
        project.ProjectName,
        Tasks = project.Tasks.Where(task => task.Status == someStatus),
    });

请注意,由于此更改,您需要将内部中继器的数据源更改为Eval("Tasks")而不是您拥有的数据源。

于 2013-06-26T18:58:38.637 回答
0
var TasksForProject = from p in Project
join t in Tasks on p.ProjectID equals t.ProjectID
where t.Satus !=null and t.status==SomeStatus
select new {
p,t
}

之后,您可以使用 tolist() 将其记入内存,然后您可以根据属性进行分组。

于 2013-07-16T09:51:25.057 回答