在ASP.NET Core MVC中,您可以通过使用相关实体模型和导航属性来访问复杂数据模型中的相关数据。以下是一个简单的代码示例,用于演示如何读取复杂数据模型中的相关数据。
首先,我们创建两个实体模型:Customer和Order。Customer模型具有多个Order,因此我们将在Customer模型中添加一个ICollection
public class Customer
{
public int Id { get; set; }
public string Name { get; set; }
public ICollection Orders { get; set; }
}
public class Order
{
public int Id { get; set; }
public string Product { get; set; }
public int Quantity { get; set; }
public int CustomerId { get; set; }
public Customer Customer { get; set; }
}
然后,我们可以在控制器中查询Customer和Order集合,以获取与特定客户相关的所有订单。以下是一个查询示例:
public IActionResult Details(int id)
{
var customer = _context.Customers.Where(c => c.Id == id)
.Include(c => c.Orders)
.FirstOrDefault();
if (customer == null)
{
return NotFound();
}
return View(customer);
}
在此示例中,我们使用Include方法将所有与该客户相关联的订单加载到Customer对象中。然后,我们可以在视图中访问这些属性,例如:
@model Customer
@Model.Name
Product
Quantity
@foreach (var order in Model.Orders)
{
@order.Product
@order.Quantity
}
通过这种方式,您可以轻松地读取和显示复杂的实体模型。