asp.net – 从两个表(join)获取数据,并使用linq返回结果

前端之家收集整理的这篇文章主要介绍了asp.net – 从两个表(join)获取数据,并使用linq返回结果前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有两个表:Projects和ProjectsData,我想使用join执行查询,并在View中获取结果。

在控制器我有这个代码

ViewBag.projectsData = (from pd in db.ProjectsData
                                   join p in db.Projects on pd.ProjectId equals p.ID
                                   where pd.UserName == this.HttpContext.User.Identity.Name 
                                   orderby p.Name,p.ProjectNo
                                   select new { ProjectData = pd,Project = p });

在视图中我应该使用什么来提取这些数据。我试过:

@foreach (var item in ViewBag.projectsData)
{
    @item.pd.UserName
}

但它不工作…

@H_502_13@解决方法
在您的视图中,您尝试访问pd属性,但此属性不存在。该属性称为ProjectData。

据说我强烈建议您使用视图模型和强类型视图而不是ViewBag。这样,您也可以在您的视图中获得Intellisense,这将帮助您选择正确的名称

因此,您可以先定义一个视图模型,其中包含您的视图所需的所有信息:

public class Myviewmodel
{
    public ProjectData ProjectData { get; set; }
    public Project Project { get; set; }
}

然后在您的控制器操作中填充此视图模型并传递给视图:

public ActionResult Index()
{
    var viewmodel = 
        from pd in db.ProjectsData
        join p in db.Projects on pd.ProjectId equals p.ID
        where pd.UserName == this.HttpContext.User.Identity.Name 
        orderby p.Name,p.ProjectNo
        select new Myviewmodel { ProjectData = pd,Project = p };
    return View(viewmodel);
}

最后在您的强类型视图中使用视图模型:

@model IEnumerable<AppName.Models.Myviewmodel>
@foreach (var item in Model)
{
     <div>@item.ProjectData.UserName</div>
}

猜你在找的asp.Net相关文章