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();
}
我现在该如何在视图中显示它们?
我建议创建一个新的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