导航属性

实体框架 中的导航属性提供了一种在两个实体类型之间导航关联的方法。 导航属性在概念模型中由 NavigationProperty 元素 (CSDL) 定义。 针对对象参与到其中的每个关系,各对象均可以具有导航属性。 使用导航属性,您可以在两个方向上导航和管理关系,如果重数为一或者零或一,则返回EntityReference,或者如果重数为多个,则返回 EntityCollection。 也可以选择单向导航,这种情况下可以删除导航属性。有关更多信息,请参见How to: Edit and Delete Navigation Properties

在使用实体框架 生成的类时,将为参与到关系的对象创建导航属性。 有关在 POCO 实体中使用导航属性的信息,请参见 创建 POCO 代理的要求(实体框架)

修改关系

可以使用导航属性更改关系。 下面的示例通过使用 Order 对象的 Customer 导航属性访问与该订单关联的客户引用,从而将其他客户分配给一个订单:order.Customer = customer

下面的示例通过使用 Orders 导航属性访问属于 customer 的 orders 集合,从而将订单添加到现有客户订单:

customer.Orders.Add(order).

在外键关联中,通过设置依赖对象的外键属性,可以形成或更改关系,如下面示例所示:

order.CustomerID = CustomerID.

有关独立键和外键关联的更多信息,请参见 定义和管理关系(实体框架)

可以使用导航属性加载通过定义的关联与实体相关的对象。 有关更多信息,请参见 加载相关对象(实体框架)和 如何:使用导航属性导航关系(实体框架)

导航关系

以下示例采用基于方法的查询语法,使用 SelectMany 方法以获取其姓氏为“Zhou”的联系人的所有订单。 Contact.SalesOrderHeader 导航属性用于获取每个联系人的 SalesOrderHeader 对象的集合。

Dim lastName = "Zhou"
Using context As New AdventureWorksEntities
    Dim ordersQuery = context.Contacts _
    .Where(Function(c) c.LastName = lastName) _
    .SelectMany(Function(o) o.SalesOrderHeaders)

    For Each order In ordersQuery
        Console.WriteLine("Order ID: {0}, Order date: {1}, Total Due: {2}", _
                order.SalesOrderID, order.OrderDate, order.TotalDue)
    Next
End Using
string lastName = "Zhou"; 
using (AdventureWorksEntities context = new AdventureWorksEntities()) 

    IQueryable<SalesOrderHeader> ordersQuery = context.Contacts 
        .Where(c => c.LastName == lastName) 
        .SelectMany(c => c.SalesOrderHeaders); 
 
    foreach (var order in ordersQuery) 
    { 
        Console.WriteLine("Order ID: {0}, Order date: {1}, Total Due: {2}", 
            order.SalesOrderID, order.OrderDate, order.TotalDue); 
    } 
原文地址:https://www.cnblogs.com/QQ862668193/p/6726333.html