Ошибка при использовании EntityCollection.Add () EF 4.1 - PullRequest
0 голосов
/ 02 сентября 2011

Я пытаюсь добавить один прокси-объект (контакт) к свойству коллекции в другом прокси-объекте (клиент). Строка collectionProperty.Add(entityModel); выдает ошибку,

Наилучший перегруженный метод соответствует для 'System.Data.Objects.DataClasses.EntityCollection.Add (HTS.Models.Contact)'
имеет недопустимые аргументы

Что я здесь не так делаю?

public dynamic AddNew(
    Type entityType,
    string modelParentType,
    int? modelParentId,
    string collectionName
    )
{
    var parentType = Type.GetType("HTS.Models." + modelParentType);
    var parentModel = Set(parentType).Find(modelParentId);
    Set(parentType).Attach(parentModel);

    var entityModel = Set(entityType).Create();

    //var foreignKeyProperty = entityType.GetProperty(modelParentType + "Id");
    //if (foreignKeyProperty != null)
    //{
    //  foreignKeyProperty.SetValue(entityModel, modelParentId, null);
    //}

    var collectionProperty = (dynamic)parentType
                            .GetProperty(collectionName)
                            .GetValue(parentModel, null);
    collectionProperty.Add(entityModel);

    SaveChanges();
    return entityModel;
}

Модель, которая использовалась для генерации ошибки - прошу прощения за все аннотации, я все еще учусь.

public class Contact : SocialEntity {
    public Contact() { Bag["DisplayName"] = "Contact"; }
    [UIHint("hidden")]
    public virtual int? CustomerId { get; set; }
    [UIHint("NoEdit ManyToMany")]
    public virtual ICollection<Customer> Customers { get; set; }
}
public class Customer : SocialEntity {
    public Customer() { Bag["DisplayName"] = "Customer"; }
    [Display(Name="Contacts", ShortName="Contact")] [UIHint("ManyToMany")]
    public virtual ICollection<Contact> Contacts { get; set; }
    //[Display(Name="Sales")] [UIHint("NoEdit")]
    //public virtual ICollection<Sale> Sales { get; set; }
}
public class SocialEntity : BaseEntity {
    [Display(Name="Name")]
    public virtual string Name { get; set; }
    [Display(Name="Addresses",ShortName="Address")]
    public virtual ICollection<Address> Addresses { get; set; }
    [Display(Name="PhoneNumbers",ShortName="PhoneNumber")]
    public virtual ICollection<PhoneNumber> PhoneNumbers { get; set; }
    [Display(Name="EmailAddresses",ShortName="EmailAddress")]
    public virtual ICollection<EmailAddress> EmailAddresses { get; set; }
}
public class BaseEntity : Base { }
public class Base
{
    public Base()
    {
        TypeName = this.GetType().BaseType.Name;
        //EntityState = 16;
    Bag = new Dictionary<string,string>();
    Bag["AlignRight"] = "AlignRight";
        Bag["DisplayName"] = "";
    }
    [UIHint("hidden")] [Display(Name="Id")]
    public virtual int Id { get; set; }
    [ScaffoldColumn(false)]
    public virtual string empty { get; set; }
    [NotMapped] [UIHint("hidden")]
    public virtual string TypeName { get; set; }
    [NotMapped] [UIHint("hidden")]
    public virtual int? EntityState { get; set; }
    [NotMapped] [ScaffoldColumn(false)]
    public virtual bool? IsSavable { get; set; }
    [NotMapped] [ScaffoldColumn(false)]
    public virtual bool? Visited { get; set; }
    [NotMapped]
    [ScaffoldColumn(false)]
    public virtual Dictionary<string,string> Bag { get; set; }
}

РЕДАКТИРОВАТЬ: Вот код, который вызывает AddNew()

public dynamic FindOrAddNew(
    string entityType,
    int? id,
    string modelParentType,
    int? modelParentId
    )
{
    var type = Type.GetType("HTS.Models." + entityType);
    var parentType = Type.GetType("HTS.Models." + modelParentType);
    dynamic entity = null;
    if (id != null)
    {
        entity = Set(type).Find(id);
    }
    else
    {
        string collectionName = "";
        ModelMetadata metadata = null;
        foreach (PropertyInfo prop in parentType.GetProperties())
        {
            metadata = ModelMetadataProviders.Current
                            .GetMetadataForProperty
                            (
                                null, parentType, prop.Name
                            );
            if (metadata.ShortDisplayName == entityType)
            {
                collectionName = prop.Name;
                if (metadata.TemplateHint != null
                    && metadata.TemplateHint.Contains("ManyToMany"))
                {
                    entity = AddNew(type, modelParentType, modelParentId, collectionName);
                }
                else
                {
                    entity = AddNew(type, modelParentType, modelParentId);
                }
                collectionName = "";
            }
        }
    }
    return entity;
}

РЕДАКТИРОВАТЬ: Вот код, который вызывает FindOrAddNew()

public ActionResult Edit(
    string responseType,
    string modelType,
    int? modelId,
    string modelPrefix,
    string modelParentType,
    int? modelParentId
    )
{
    if (modelType == null) // temporary initializer
    {
        modelType = "Customer";
        modelId = 1;
    }

    var entity = db.FindOrAddNew(modelType, modelId, modelParentType, modelParentId);
    SetSelectList(db, entity);

    if (responseType == "Partial")
    {
        ViewData.TemplateInfo.HtmlFieldPrefix = modelPrefix;
        ViewData["indexed"] = true;
        entity.IsSavable = false;
        return PartialView(entity);
    }
    else
    {
        entity.IsSavable = true;
        return View(entity);
    }
}

//SAVE
public void Save([ModelBinder(typeof(CustomModelBinder))] dynamic model)
{
    db.Update(model, null, "");
    db.SaveChanges();
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...