Entity Framework中删除主子表对象

在使用Entity Framework一同删除主子表对象时,需要注意的问题:

1.不能直接使用context.Delete(masterobject);会造成其子对象的主键导航属性为null,无法保存。

   使用的方法为:先循环删除其子对象

 

ExpandedBlockStart.gif View Code
             int id = (bindingSource1.Current  as Client).ID;
            Client model = md.Client.Where(r => r.ID == id).FirstOrDefault();
             int count = model.DepartMent.Count;
             // 不能一次删除多个,比如md.DeleteObject(model.DepartMent)。
            
//  或者md.DeleteObject(md.DepartMent.Where(r=>r.Client_ID==model.ID));
            
// 要一个个的删除。
             for ( int i =  0; i < count; i++)
            {
                md.DeleteObject(model.DepartMent.First());
            }
            md.DeleteObject(model); // 不能用gridview或是BindingSource的removed方法,他们会删掉该条记录的外间引用对象,造成不能保存

  然后再删除主对象。

ExpandedBlockStart.gif View Code
            md.DeleteObject(model); // 不能用gridview或是BindingSource的removed方法,他们会删掉该条记录的外间引用对象,造成不能保存

      

2.在删除时,不能使用数据源或是控件的删除行的方法。否则也会出现导航属性为null的情况。


转载于:https://www.cnblogs.com/redbaby/archive/2011/10/19/2217174.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值