Запись измененных значений с помощью DBContext Entry.OriginalValues ​​и Entry.NewValues - PullRequest
2 голосов
/ 04 февраля 2012

У меня есть сайт библиотеки документов, и я хотел бы отправить электронное письмо при редактировании объекта документа, содержащее сводку изменений.

Взаимодействие с базой данных - это Code First Entities Framework с использованием DBContext

Вот что у меня пока есть:

    [HttpPost]
    public ActionResult Edit(Document document, bool sendEmail, string commentsTextBox)
    {

        if (ModelState.IsValid)
        {
            docsDB.Entry(document).State = EntityState.Modified;

            foreach (string propertyName in docsDB.Entry(document).OriginalValues.PropertyNames)
            {
                var OriginalValue = docsDB.Entry(document).OriginalValues.GetValue<object>(propertyName);
                var NewValue = docsDB.Entry(document).CurrentValues.GetValue<object>(propertyName);
                if (!OriginalValue.Equals(NewValue))
                {
                    //capture the changes
                }
            }

            docsDB.SaveChanges();
            if (sendEmail)
            {
               //sends email
            }
            return RedirectToAction("Index");

        }

Однако OriginalValue и NewValue всегда одинаковы - значения обновления.

Есть ли способ, если что-то не хватаетхакать, как запись в файл, чтобы зафиксировать состояние документа перед POST?

1 Ответ

5 голосов
/ 04 февраля 2012

Для сравнения обновленных свойств со значениями в базе данных необходимо перезагрузить документ из базы данных. Вы можете попробовать это так:

[HttpPost]
public ActionResult Edit(Document document, bool sendEmail,
    string commentsTextBox)
{
    if (ModelState.IsValid)
    {
        var documentInDB = docsDB.Documents.Single(d => d.Id == document.Id);

        docsDB.Entry(documentInDB).CurrentValues.SetValues(document);

        foreach (string propertyName in docsDB.Entry(documentInDB)
                                        .OriginalValues.PropertyNames)
        {
            var OriginalValue = docsDB.Entry(documentInDB)
                                .OriginalValues.GetValue<object>(propertyName);
            var NewValue = docsDB.Entry(documentInDB)
                           .CurrentValues.GetValue<object>(propertyName);

            if (!OriginalValue.Equals(NewValue))
            {
                //capture the changes
            }
        }

        docsDB.SaveChanges();
        if (sendEmail)
        {
           //sends email
        }
        return RedirectToAction("Index");
    }
    // ...
}
...