使用LINQ从kendo UI中的网格中删除上下文记录

时间:2013-06-21 13:24:43

标签: asp.net-mvc linq entity-framework kendo-ui

您好我在我的项目中使用了kendo ui网格。

这是我在数据库中插入记录的代码。

 public static void Insert(StudentViewModel student)
        {
            student.StudentId = All().OrderByDescending(p => p.StudentId).First().StudentId + 1;

            //All().Insert(0, student);
             UniRegEntities uniRegEntities = new UniRegEntities();
            Student stu =new Student();
            stu.FName = student.FirstName;
            stu.LName = student.LastName;
            stu.Gender = uniRegEntities.Genders.Where(x => x.Title == student.Gender).FirstOrDefault();
            stu.Id = student.StudentId;

            uniRegEntities.Students.Add(stu);
            uniRegEntities.SaveChanges();
        }

这是我的更新声明。

 public static void Update(StudentViewModel student)
        {
          UniRegEntities context = new UniRegEntities();
            var studentToUpdate = context.Students.Where(x => x.Id == student.StudentId).FirstOrDefault();
            studentToUpdate.FName = student.FirstName;
            studentToUpdate.LName = student.LastName;
            studentToUpdate.Gender = context.Genders.Where(x => x.Title == student.Gender).FirstOrDefault();
            context.SaveChanges();

        }

任何人都可以向我推荐删除方法吗?

3 个答案:

答案 0 :(得分:0)

你可以试试下面的代码片段吗?

using (var db= new AppContext(ConnectionStr))
{
        try
        {
            con.Configuration.AutoDetectChangesEnabled = false;
            var o = new Student { StudentId = student.StudentId };
            db.Students.Attach(o);
            db.Students.Remove(o);
            db.SaveChanges();
        }
        catch (Exception ex)
        {
            throw new Exception(ex.InnerException.Message);
        }
        finally
        {
            con.Configuration.AutoDetectChangesEnabled = true;
        }
}

答案 1 :(得分:0)

您可以从数据库中获取实体,然后将其删除或创建一个实体,然后将其删除。

所以:

var e = // Get
ctx.DeleteObject(e);
ctx.SaveChanges();

var e = new Foo() { FooId = id };
ctx.Entity.Attach(e);
ctx.DeleteObject(e);
ctx.SaveChanges();

适用于您的情况:

您正在获取记录,因此您想使用DeleteObject()

public static void Update(StudentViewModel student)
{
    UniRegEntities context = new UniRegEntities();

    var studentToDelete = context.Students.Where(x => x.Id == student.StudentId).FirstOrDefault();

    context.Students.DeleteObject(studentToUpdate);
    context.SaveChanges();
}

答案 2 :(得分:0)

context.Students.Remove(context.students.Single(x=>x.Id==student.Id));