实体框架 中的导航属性提供了一种在两个实体类型之间导航关联的方法。 导航属性在概念模型中由 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);
}
}