导航属性

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值