无法从ICollection中删除最后一项

时间:2014-12-14 21:04:08

标签: c# .net asp.net-mvc entity-framework asp.net-mvc-4

我正在尝试从集合中删除最后一项,但它无法正常工作。我首先使用MVC 4和EF Code。我生成所有视图和控制器并添加带复选框的模块,每个复选框都用于一个类型集合的对象。

这是我的模特:

{
    public class Efekt
    {
        public int ID { get; set; }
        public string Symbol { get; set; }
        public string Typ { get; set; }

        [DataType(DataType.MultilineText)]
        public string Opis { get; set; }

        [DataType(DataType.MultilineText)]
        public string Odnosnik
        {
            get
            {
                (...)
            }

           // set;
        }

        public virtual ICollection<Obszarowe> EfektyObszarowe { get; set; }
        public virtual ICollection<Przedmiot> Przedmioty { get; set; }

        public Efekt(){

        }

        public Efekt(string symbol,string opis,string odnosnik){

           (...)
        }
    }
}


{
    public class Obszarowe
    {
        public int ID { get; set; }
        public string Symbol { get; set; }
        public string Typ { get; set; }

        [DataType(DataType.MultilineText)]
        public string Opis { get; set; }

        [DataType(DataType.MultilineText)]
        public string Odnosnik
        {
            get
            {
                (...)
            }

            // set;
        }

        public virtual ICollection<Efekt> EfektyKierunkowe { get; set; }

        public Obszarowe(){

        }

        public Obszarowe(string symbol, string opis, string odnosnik)
        {

            (...)
        }
    }
}

和efektcontroller中的编辑功能

 public ActionResult Edit(int id = 0)
        {
            Efekt efekt = db.Efekts.Find(id);
            if (efekt == null)
            {
                return HttpNotFound();
            }
            EfektyObszarowe(efekt);
            return View(efekt);
        }

        private void EfektyObszarowe(Efekt efekt)
        {
            var allObszarowe = db.EfektyObszarowe;
            var kierunkoweObszarowe = new HashSet<int>(efekt.EfektyObszarowe.Select(c => c.ID));
            var viewModel = new List<KierunkoweObszarowe>();
            foreach (var obszar in allObszarowe)
            {
                viewModel.Add(new KierunkoweObszarowe
                {
                    ID = obszar.ID,
                    Symbol = obszar.Symbol,
                    Wybrany = kierunkoweObszarowe.Contains(obszar.ID)
                });
            }
            ViewBag.Courses = viewModel;
        }

        //
        // POST: /Efekt/Edit/5

        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Edit(int id , string[] selectedCourses)
        {
            Efekt efekt = db.Efekts.Find(id);

            if (ModelState.IsValid)
            {
                UpdateObszarowe(selectedCourses, efekt);

                db.Entry(efekt).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            EfektyObszarowe(efekt);
            return View(efekt);
        }

        private void UpdateObszarowe(string[] selectedCourses, Efekt instructorToUpdate)
        {
            if (selectedCourses == null)
            {
                instructorToUpdate.EfektyObszarowe = new List<Obszarowe>();
                return;
            }

            var selectedCoursesHS = new HashSet<string>(selectedCourses);
            var instructorCourses = new HashSet<int>
                (instructorToUpdate.EfektyObszarowe.Select(c => c.ID));
            //var temp = db.Efekts.Find(instructorToUpdate.ID);
           ///////// Obszarowe ob;

            foreach (var course in db.EfektyObszarowe)
            {
                if (selectedCoursesHS.Contains(course.ID.ToString()))
                {
                 if (!instructorCourses.Contains(course.ID))
                {
                     instructorToUpdate.EfektyObszarowe.Add(course);
                /*ob = db.EfektyObszarowe.Find(Int32.Parse(course));
                        instructorToUpdate.EfektyObszarowe.Add(ob);
                */

                    }
                }
                else
                {
                    if (instructorCourses.Contains(course.ID))
                    {
                        instructorToUpdate.EfektyObszarowe.Remove(course);
                    }   
                }
            }
        }

当我取消选中&#34; Obszarowe&#34;的复选框时没关系,从集合中删除项目,我只看到已检查的对象,但当我取消选中所有没有区别时:(对不起我的英文

enter image description here

1 个答案:

答案 0 :(得分:3)

你做......

instructorToUpdate.EfektyObszarowe = new List<Obszarowe>();

但是您要通过...

获取instructorToUpdate
Efekt efekt = db.Efekts.Find(id);

这意味着未加载EfektyObszarowe集合,因此不会跟踪更改。因此,您必须在获取Efekt

时加载集合
Efekt efekt = db.Efekts.Include(e => e.EfektyObszarowe).Single(e.ID == id);