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

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

在控制器我有这个代码

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

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

  1. @foreach (var item in ViewBag.projectsData)
  2. {
  3. @item.pd.UserName
  4. }

但它不工作…

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

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

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

  1. public class Myviewmodel
  2. {
  3. public ProjectData ProjectData { get; set; }
  4. public Project Project { get; set; }
  5. }

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

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

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

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

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