zoukankan      html  css  js  c++  java
  • 导航属性

    实体框架 中的导航属性提供了一种在两个实体类型之间导航关联的方法。 导航属性在概念模型中由 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); 
        } 
  • 相关阅读:
    多项式乘法
    容斥计算多重组合
    D. Tokitsukaze, CSL and Stone Game
    优惠买商品(dp、greedy)
    数星星(单点更新,求前缀和)
    信息推送(单点更新,求前缀和)
    互相送礼物
    Codeforces Round #611 (Div. 3)E. New Year Parties
    多源bfs
    mysql事务和锁
  • 原文地址:https://www.cnblogs.com/QQ862668193/p/6726333.html
Copyright © 2011-2022 走看看