简体   繁体   English

无法使用asp.net/c#在实体框架中编辑

[英]Not able to edit in entity framework with asp.net/c#

 public ReturnMessage EditCategories(Category objCategory)
    {


        ReturnMessage objReturnMessage = new ReturnMessage();
        try
        {
            Category objCategoryNew = db.Categories.Where(x => x.CategoryId == objCategory.CategoryId).FirstOrDefault();
            if (objCategoryNew != null)
            {
                objCategoryNew = objCategory;
                db.SaveChanges();
                objReturnMessage.isSuccessfull = true;
                objReturnMessage.responseMessage = "Successfully updated.";
            }
            else
            {
                objReturnMessage.isSuccessfull = false;
                objReturnMessage.responseMessage = "Category not present.";
            }
        }
        catch (Exception ex)
        {
            objReturnMessage.isSuccessfull = false;
            objReturnMessage.responseMessage = ex.Message;
        }
        return objReturnMessage;

    }

Everything goes fine there are no exceptions still the data isn't getting updated. 一切顺利,没有例外,数据没有得到更新。 I don't know what's the issue. 我不知道是什么问题。 Please help? 请帮忙?

The line: 这条线:

objCategoryNew = objCategory;

will not work out since you change the reference objCategoryNew to objCategory , not the object itself, what you have to do is to assign each property of objCategory to objCategoryNew , something like: 因为你改变了参考行不通了objCategoryNewobjCategory ,不是对象本身,你有什么要做的就是每个属性分配objCategoryobjCategoryNew ,是这样的:

objCategoryNew.Pro1 = objCategory.Pro1;
objCategoryNew.Pro2 = objCategory.Pro2;
....

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM