加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 实体框架CTP5,代码优先.可选的导航属性

发布时间:2020-12-15 21:01:22 所属栏目:asp.Net 来源:网络整理
导读:我正在使用Entity Framework CTP5(代码优先),我有两个类: public class Order{ public int Id {get;set;} public decimal SomeOtherProperty1 {get;set;} //navigation property public virtual ICollectionOrderLine OrderLines { get; set; } } 和 public
我正在使用Entity Framework CTP5(代码优先),我有两个类:
public class Order
{
   public int Id {get;set;}
   public decimal SomeOtherProperty1 {get;set;}

   //navigation property
   public virtual ICollection<OrderLine> OrderLines { get; set; }  
}

public class OrderLine
{
   public int Id {get;set;}
   public int OrderId {get;set;}
   public decimal SomeOtherProperty2 {get;set;}

   //navigation property
   public virtual Order Order { get; set; }
}

我有OrderLine类的以下配置类:

public partial class OrderLineMap : EntityTypeConfiguration<OrderLine>
    {
        public OrderLineMap()
        {
            this.HasKey(ol=> ol.Id);

            this.HasRequired(ol=> ol.Order)
                .WithMany(o => o.OrderLines)
                .HasForeignKey(ol=> ol.OrderId);

        }
    }

目前,如果您创建“OrderLine”实例,则必须指定“订单”实例.

问题:如何使ol.Order属性可选(在某些情况下为null)?可能吗?

解决方法

OrderLine上现在需要Order的原因是因为您在流畅的API代码中使用了HasRequired()来配置关联.我们只需将其更改为HasOptional,如下面的代码所示:
this.HasOptional(ol => ol.Order)
    .WithMany(o => o.OrderLines)
    .HasForeignKey(ol => ol.OrderId);

这将基本上使OrderLines.OrderId列成为DB中的(INT,NULL),以便OrderLine记录是独立的.我们还需要通过在OrderLine类上使OrderId为空来反映对象模型中的这种变化:

public class OrderLine
{
    public int Id { get; set; }
    public int? OrderId { get; set; }
    public decimal SomeOtherProperty2 { get; set; }

    public virtual Order Order { get; set; }
}

现在,您可以保存OrderLines而无需为它们指定订单.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读