EF用导航属性遍历从表时,删除主表出错

var entitys= Repository.Table.Where(a => ids.Contains(a.UUID)).ToList();
 entitys.ForEach(a =>
 {
   //foreach (var deductionitem in a.Deductionitems){} //取出来就删除不了了

  var items=a.Deductionitems
  DoDelete(a);
});

 


DeductionItems和主表配了级联删除,代码执行时会抛The relationship could not be changed because one or more of the foreign-key properties is non-nullable

场景为:删除主表时,在其对应的子表集合中,从子表通过导航属性去更新另外一个表的某个合计字段

 

解决方法:

遍历子表后,EF无法分辨该记录是否要保留。所以需要手动删除从表,不能再依赖级联删除

 

附上主表实体部分字段

public class MaterialSupplierPayApply : BaseSupplierPayApply
    {
        public MaterialSupplierPayApply() { }

        public MaterialSupplierPayApply(Currency currency, decimal exchangeRate, MaterialSupplier supplier) 
            : base(currency, exchangeRate, supplier)
        {

        }

        public override string SysBillTypeCode => FuncCodeConst.Scm.MATERIALSUPPLIERPAYAPPLY;

        private List<MaterialSupplierPayDeductionItem> _deductionItems;
        /// <summary>
        /// 应付扣款明细
        /// </summary>
        public virtual List<MaterialSupplierPayDeductionItem> DeductionItems
        {
            get => _deductionItems ?? (_deductionItems = new List<MaterialSupplierPayDeductionItem>());
            set => _deductionItems = value;
        }

    }

以下为子表实体


/// <summary>
/// 应付扣款明细
/// </summary>
public class MaterialSupplierPayDeductionItem:BaseEntityLog
    {
        public MaterialSupplierPayDeductionItem() { }

        public MaterialSupplierPayDeductionItem(MaterialSupplierPayableDeduction materialSupplierPayableDeduction,Guid billId)
        {
            BillId = billId;
            materialSupplierPayableDeduction.WriteOffStatus = WriteOffStatus.WriteOffing;
            MaterialSupplierPayableDeduction = materialSupplierPayableDeduction;
        }

        /// <summary>
        /// 付款申请
        /// </summary>
        public Guid BillId { get; set; }

        /// <summary>
        /// 材料商应付扣款Id
        /// </summary>
        public Guid MaterialSupplierPayableDeductionId { get; set; }

        /// <summary>
        /// 备注
        /// </summary>
        public string Description { get; set; }

        #region 导航属性

        /// <summary>
        /// 材料商付款申请
        /// </summary>
        public virtual MaterialSupplierPayApply MaterialSupplierPayApply { get; set; }

        /// <summary>
        /// 材料商应付扣款
        /// </summary>
        public virtual MaterialSupplierPayableDeduction MaterialSupplierPayableDeduction { get; set; }

        #endregion
    }

 

posted @ 2020-05-27 18:49  Cyril-Hcj  阅读(276)  评论(7编辑  收藏  举报