C#:出现“无法删除此对象,因为未在 ObjectStateManager 中找到它”的解决方案

前言

        最近在写C#程序,要求通过EF三层架构实现对数据库的增、删、改、查等操作。增加、修改都写得比较丝滑,没啥大问题。直到我开始写删除操作,跑起来VS给我报错......

问题

         这是啥意思?找不到该对象?

        我第一反应就是是不是参数没传进去,我就往前扒拉我的函数,欸,没问题啊,参数传得好好的,怎么就找不到对象呢?

解决方案

        查阅了多方资料之后,我找到了解决方法。

        可能是因为EF三层架构的原因,会出现这个问题。ObjectStateManager是维护实体类型实例和关系实例的对象状态和标识管理。实际上没有在ObjectStateManager中找到是因为没有找到删除的状态。所以这里我们先要将要删除的目标对象的状态设置为删除,就能顺利完成啦!

代码

原来有问题的代码:

        public int Delete(db2 db2)  //删除记录
        {
            myDbContext = new MydbContext();
            myDbContext.Set<db2>().Remove(db2); //报错段
            int n = myDbContext.SaveChanges();
            myDbContext.Dispose();
            return n;
        }

  修改之后:

        public int Delete(db2 db2)  //删除记录
        {
            myDbContext = new MydbContext();
            //设置为删除状态
            myDbContext.Entry(db2).State = EntityState.Deleted; 
            myDbContext.Set<db2>().Remove(db2);
            int n = myDbContext.SaveChanges();
            myDbContext.Dispose();
            return n;
        }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值