Entity Framework: проверка всех отношений объекта не удалась в 6.1.1

Мне удалось использовать этот код для проверки всех отношений при использовании Entity Framework ver. 5. (из yildizm85, Entity Framework : проверить все отношения сущности на использование внешнего ключа)

public bool IsUnitNameInRelationship(UnitName unitName)
{
  bool hasRelation = false;
  var allRelatedEnds = ((IEntityWithRelationships)unitName).RelationshipManager.GetAllRelatedEnds();
  foreach (var relatedEnd in allRelatedEnds)
  {
    if (relatedEnd.GetEnumerator().MoveNext())
    {
      hasRelation = true;
      break;
    }
  }
  return hasRelation;
}

После обновления до EF 6.1.1 происходит сбой. Сообщение об ошибке:

Unable to cast object of type 'System.Data.Entity.DynamicProxies.UnitName_F023365757AB452259D6FFA34E2DC147E423592BFB4A49619F41A60AA3AF5ECA' to type 'System.Data.Objects.DataClasses.IEntityWithRelationships'.

Есть ли лучший подход для проверки всех отношений с использованием EF 6.1.1?


person Community    schedule 12.07.2014    source источник


Ответы (1)


У меня была такая же проблема с приведением экземпляров динамического прокси для сущностей к интерфейсу IEntityWithRelationships с EF 6.1.3! И поскольку у меня нет свойств навигации для всех связанных сущностей моего родителя, я придумал этот код на основе отражения, чтобы в конечном итоге получить экземпляр RelationshipManager:

var entityProxy = DbContext.FooBars.First(fb => fb.Id == someId);
var proxyType = entityProxy.GetType();

var wrapperField = proxyType.GetField("_entityWrapper");
var wrapper = wrapperField.GetValue(entityProxy);
var wrapperType = wrapper.GetType();

var relManProp = wrapperType.GetProperty("RelationshipManager");
Debug.Assert(relManProp != null, nameof(relManProp) + " != null");
var relMan = (RelationshipManager)relManProp.GetValue(wrapper);

var allEnds = relMan.GetAllRelatedEnds();
foreach (var relatedEnd in allEnds)
{
    Debug.Print("RELATIONSHIP-NAME:" + relatedEnd.RelationshipName);
} 
person w00zla    schedule 19.09.2018
comment
Я думаю, вам нужно быть немного осторожным с использованием var wrapperField = proxyType.GetField("_entityWrapper");, потому что, если ваша база данных содержит много записей (скажем, более 100000 строк), вы получите небольшую проблему с производительностью. - person Gwasshoppa; 11.03.2021