Помогите Линк в Sql - PullRequest
0 голосов
/ 13 мая 2009

Почему я получаю исключение, когда ApplyPropertyChanges ???

Код почти такой же, когда я редактирую пользовательскую таблицу, но не работает с моей таблицей новостей.

Создание, удаление и детали работают нормально, но когда я пытаюсь редактировать новости, я получаю исключение ниже:

ObjectStateManager не содержит ObjectStateEntry 'MagixCMS.Models.noticia'

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace MagixCMS.Models
{
    public class NoticiaRepository : INoticiaRepository
    {
        #region INoticiaRepository Members

        magixcmsEntities _entities = new magixcmsEntities();

        public noticia CreateNoticia(noticia noticiaToCreate)
        {
            _entities.AddTonoticiaSet(noticiaToCreate);
            _entities.SaveChanges();
            return noticiaToCreate;
        }

        public void DeletaNoticia(noticia noticiaToDelete)
        {
            var noticiaOriginal = GetNoticia(noticiaToDelete.Id);
            _entities.DeleteObject(noticiaOriginal);
            _entities.SaveChanges();
        }

        public noticia EditNoticia(noticia noticiaToEdit)
        {
            var noticiaOriginal = GetNoticia(noticiaToEdit.Id);
            _entities.ApplyPropertyChanges(noticiaToEdit.EntityKey.EntitySetName, noticiaToEdit); //EXCEPTION HERE
            _entities.SaveChanges();
            return noticiaToEdit;
        }

        public noticia GetNoticia(int id)
        {
            return (from c in _entities.noticiaSet where c.Id == id select c).FirstOrDefault();
        }

        public IEnumerable<noticia> ListNoticias()
        {
            return _entities.noticiaSet.ToList();
        }

        #endregion
    }
}

Я исключил Google и не нашел большой помощи.

1 Ответ

0 голосов
/ 13 мая 2009

Я решаю это.

Проблема в модели EF.

Чтобы решить эту проблему, вам потребуется метод расширения для сохранения ваших данных:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Objects;
using System.Data.Objects.DataClasses;

namespace MagixCMS.Models
{
    public static class Extensions
    {
        public static void Update(ObjectContext context, string entitySetName, IEntityWithKey entity)
        {
            entity.EntityKey = context.CreateEntityKey(entitySetName, entity);
            context.Attach(entity);
            var stateEntry = context.ObjectStateManager.GetObjectStateEntry(entity.EntityKey);
            var propertyNameList = stateEntry.CurrentValues.DataRecordInfo.FieldMetadata.Select(pn => pn.FieldType.Name);
            foreach (var propName in propertyNameList)
            {
                stateEntry.SetModifiedProperty(propName);
            }
        }
    }
}

И в методе Edit вы делаете:

public noticia EditNoticia(noticia noticiaToEdit)
{
    //GET THE CONTEXT FOR THE ENTITY
    ObjectContext _context = this._entities.noticiaSet.Context;
    var noticiaOriginal = GetNoticia(noticiaToEdit.Id);
    //UPDATE THE ORIGINAL ENTITY WITH THE NEW VALUES
    Extensions.Update(_context, noticiaOriginal.EntityKey.EntitySetName, noticiaToEdit);
    //PERSIST THE DATA
    _entities.SaveChanges();
    return noticiaToEdit;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...