错误:无法删除对象,因为在ObjectStateManager中找不到该对象。 C#

时间:2013-01-07 20:11:49

标签: c# asp.net

我正在尝试从表Ent_El_Tags{entel_id,tag_id}中删除数据,当我将删除函数应用于我在下面声明的关系但是它适用于添加功能时,我遇到错误。

    [HttpPost]
    public List<Ent_El_Tags> AddTagsToElements([FromUri]ParamsClass parameters)
    {
        var relationships = new List<Ent_El_Tags>();
        foreach (var el in parameters.element_ids)
        {
            foreach (var t_id in parameters.tag_ids)
            {

                var relationship = new Ent_El_Tags { entel_id = el, tag_id = t_id };
                relationships.Add(relationship);
                _context.Ent_El_Tags.Add(relationship);

            }

        }
        _context.SaveChanges();
        return relationships;
    }

    [HttpPost]
    public List<Ent_El_Tags> DeleteTagsToElements([FromUri]ParamsClass parameters)
    {
        var relationships = new List<Ent_El_Tags>();           
        foreach (var el in parameters.element_ids)
        {
            foreach (var t_id in parameters.assigned_ids)
            {
                var relationship = new Ent_El_Tags { entel_id = el, tag_id = t_id };
                relationships.Add(relationship);
                _context.Ent_El_Tags.Remove(relationship);
            }
        }
        _context.SaveChanges();
        return relationships;
    }

1 个答案:

答案 0 :(得分:0)

要使用EntityFramework删除记录,您需要使用EntityFramework从数据库中获取记录,因为该对象将位于EF ObjectStateManager中。

var relationship = new Ent_El_Tags { entel_id = el, tag_id = t_id };
_context.Ent_El_Tags.Remove(relationship);

替换它
var relationship = _context.Ent_El_Tags.Where(x=>x.enterl_Id==el && x.tag_id==t_id).FirstOrDefault();
_context.Ent_El_Tags.Remove(relationship);