LinqJoinQuery-如何在视图MVC C#中显示新表

本文关键字:显示 新表 MVC 视图 LinqJoinQuery- | 更新日期: 2023-09-27 18:00:41

我在linq中进行了一个查询以连接2个类,现在问题是我想在视图中显示它,因为查询在控制器中。这是查询:

 public ActionResult JoinSupToPro()
    {
        SupplierDBContext dbS = new SupplierDBContext();
        var innerJoinQuery = from pro in db.Products join sup in dbS.Suppliers on pro.SupplierId equals sup.ID
        select new { pro.Name,pro.Price,  NameSup= sup.Name , sup.Phone,};
        return View();
    }

我现在该如何在视图中显示它们?

LinqJoinQuery-如何在视图MVC C#中显示新表

我建议创建一个新的viewmodel类来从两个不同的表中加载数据,如下所示:

public class ProductSupplier
{
    public string ProName {get; set;}
    public string Price{get; set;}
    public string SupName{get; set;}
    public string SupPhone{get; set;}
}

现在,当从controller返回数据时,您填写model并将其返回到如下视图:

public ActionResult JoinSupToPro()
{
    SupplierDBContext dbS = new SupplierDBContext();
    //Create list instance of your model
    List<ProductSupplier> model=new List<ProductSupplier>();
    var innerJoinQuery = (from pro in dbs.Products 
                         join sup in dbS.Suppliers 
                         on pro.SupplierId equals sup.ID
                         select new 
                         { 
                             proName=pro.Name,
                             proPrice=pro.Price,  
                             supName= sup.Name , 
                             supPhone=sup.Phone
                         }).ToList();//convert to List
    foreach(var item in innerJoinQuery) //retrieve each item and assign to model
    {
          model.Add(new ProductSupplier()
          {
                ProName = item.proName,
                Price = item.proPrice,
                SupName = item.supName,
                SupPhone = item.supPhone
          });
    }
    return View(model);
}

一旦模型从控制器传递过来,您就可以将其显示在视图中,如下所示:

//Refer the list instance of model in your view
@model IEnumerable<ProjectName.Models.ProductSupplier>
@foreach(var item in Model)
{
      //assign this values to any element of html
      //by referring it as @item.ProName, @item.Price etc.,
}

希望清楚

这里有两个选项,一个是使用Ajax在视图中显示此查询。有用,但您可能需要动态创建html,这取决于您想要实现的目标。

第二个是使用视图模型并在您的视图中调用此模型,因此将能够实现以下功能:

foreach(var item in model) 
{
<td>item.prop<td>
}

祝你好运!

您需要将数据传递给视图。像

return view(innerJoinQuery.ToList())

请参阅此链接了解详细信息

http://www.asp.net/mvc/overview/getting-started/introduction/accessing-your-models-data-from-a-controller