之前遇到只更新部分的问题:如前端修改用户信息(不修改密码),传实体到后台,这个实体是没有密码,这样一来要更新的话,得先去数据库通过传过来的实体的ID读取这条记录,然后将改动的部分填到查出来的记录中,再更新回去。
逻辑是对的,但是用EF,会有个问题,查出来后是默认缓存在entity这个上下文(dbcontent)中的,所以直接更新会报错,于是我就想办法查询的时候不缓存到上下文中,Asnotracking,先记录下,迟点整理,单词乱拼的,这个解决问题了。
但是,这样一来又会出现效率的降低,本来已经缓存在上下文中的,同次请求,多次用到这个记录的时候,数据库读取一次就行了,现在就是每次都要重新读取。
今天,才发现,原来要避免之前这个错误很简单,数据查出来——缓存在上下文中——实体属性变更——更新上下文。完事儿,关键就是我们不是去更新实体了,而是更新这个上下文。dbContext.saveChange();