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 }

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM