C# Linq обновить запись в базе без повторного получения объекта

программирование .net LINQ

Ситуация: есть метод который выдает объект класса базы данных
я его получаю, меняю значения объекта, дальше передаю в следующий метод который должен сохранить объект (и попутно выполнить необходимые действия), вот минипример

public void UpdateWorker(Staff item)
{
Staff worker = db.Staff.Where(s => s.id == item.id).FirstOrDefault();
worker.name = item.name;
db.SubmitChanges();

/* доп действия */
}

можно ли как то избавить от Staff worker = db.Staff.Where(s => s.id == item.id).FirstOrDefault() и перечисления полей, которым нужно задать новое значение?

Примечание:
там где я изменяю объект нет связи с базой, поэтому приходится отправлять в класс где есть эта связь

Примечание:
еще примечание: когда получаешь объект из другого класса, меняешь что-то и тут же делаешь db.SubmitChanges(), никаких действий не происходит
Ответы:
А зачем вообще делать выборку? Объект item является объектом контекста. Поэтому вам необходимо просто изменить поле объекта и отправить изменения в БД.


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.